mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
3f4fccb65f
This reduces allocs and bytes used per log entry significantly as well as some improvement to time per log operation. Each log driver, however, must put messages back in the pool once they are finished with the message. Signed-off-by: Brian Goff <cpuguy83@gmail.com>
96 lines
2.1 KiB
Go
96 lines
2.1 KiB
Go
// Package logentries provides the log driver for forwarding server logs
|
|
// to logentries endpoints.
|
|
package logentries
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/Sirupsen/logrus"
|
|
"github.com/bsphere/le_go"
|
|
"github.com/docker/docker/daemon/logger"
|
|
)
|
|
|
|
type logentries struct {
|
|
tag string
|
|
containerID string
|
|
containerName string
|
|
writer *le_go.Logger
|
|
extra map[string]string
|
|
}
|
|
|
|
const (
|
|
name = "logentries"
|
|
token = "logentries-token"
|
|
)
|
|
|
|
func init() {
|
|
if err := logger.RegisterLogDriver(name, New); err != nil {
|
|
logrus.Fatal(err)
|
|
}
|
|
if err := logger.RegisterLogOptValidator(name, ValidateLogOpt); err != nil {
|
|
logrus.Fatal(err)
|
|
}
|
|
}
|
|
|
|
// New creates a logentries logger using the configuration passed in on
|
|
// the context. The supported context configuration variable is
|
|
// logentries-token.
|
|
func New(info logger.Info) (logger.Logger, error) {
|
|
logrus.WithField("container", info.ContainerID).
|
|
WithField("token", info.Config[token]).
|
|
Debug("logging driver logentries configured")
|
|
|
|
log, err := le_go.Connect(info.Config[token])
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return &logentries{
|
|
containerID: info.ContainerID,
|
|
containerName: info.ContainerName,
|
|
writer: log,
|
|
}, nil
|
|
}
|
|
|
|
func (f *logentries) Log(msg *logger.Message) error {
|
|
data := map[string]string{
|
|
"container_id": f.containerID,
|
|
"container_name": f.containerName,
|
|
"source": msg.Source,
|
|
"log": string(msg.Line),
|
|
}
|
|
for k, v := range f.extra {
|
|
data[k] = v
|
|
}
|
|
ts := msg.Timestamp
|
|
logger.PutMessage(msg)
|
|
f.writer.Println(f.tag, ts, data)
|
|
return nil
|
|
}
|
|
|
|
func (f *logentries) Close() error {
|
|
return f.writer.Close()
|
|
}
|
|
|
|
func (f *logentries) Name() string {
|
|
return name
|
|
}
|
|
|
|
// ValidateLogOpt looks for logentries specific log option logentries-address.
|
|
func ValidateLogOpt(cfg map[string]string) error {
|
|
for key := range cfg {
|
|
switch key {
|
|
case "env":
|
|
case "labels":
|
|
case "tag":
|
|
case key:
|
|
default:
|
|
return fmt.Errorf("unknown log opt '%s' for logentries log driver", key)
|
|
}
|
|
}
|
|
|
|
if cfg[token] == "" {
|
|
return fmt.Errorf("Missing logentries token")
|
|
}
|
|
|
|
return nil
|
|
}
|