From 56bc580343fc35676a3767f18d18bf107fafb6dc Mon Sep 17 00:00:00 2001 From: Alex K <8418476+fearful-symmetry@users.noreply.github.com> Date: Fri, 31 Jan 2020 07:34:26 -0800 Subject: [PATCH] [Elastic Log Driver] Fix file check bug, deal with logging (#15935) * fix file check bug, deal with logging * add logging env fix * remove space * fix nil pointer deref * add missing blocking read call (cherry picked from commit d60e65b3d5f903958c698d19092974b75f56fbba) --- x-pack/dockerlogbeat/config.json | 8 ++++++++ x-pack/dockerlogbeat/handlers.go | 6 +++--- x-pack/dockerlogbeat/magefile.go | 10 +++++----- x-pack/dockerlogbeat/main.go | 6 +++++- x-pack/dockerlogbeat/pipelinemanager/libbeattools.go | 8 ++++---- .../dockerlogbeat/pipelinemanager/pipelineManager.go | 3 +-- 6 files changed, 26 insertions(+), 15 deletions(-) diff --git a/x-pack/dockerlogbeat/config.json b/x-pack/dockerlogbeat/config.json index 2ddf616b8c93..4927f8001749 100644 --- a/x-pack/dockerlogbeat/config.json +++ b/x-pack/dockerlogbeat/config.json @@ -10,6 +10,14 @@ "socket": "beatSocket.sock" }, "env":[ + { + "description": "debug level", + "name": "LOG_DRIVER_LEVEL", + "value": "info", + "Settable": [ + "value" + ] + }, { "description": "libbeat env hack", "name": "BEAT_STRICT_PERMS", diff --git a/x-pack/dockerlogbeat/handlers.go b/x-pack/dockerlogbeat/handlers.go index 4348b948f520..12320cee232d 100644 --- a/x-pack/dockerlogbeat/handlers.go +++ b/x-pack/dockerlogbeat/handlers.go @@ -39,7 +39,7 @@ func startLoggingHandler(pm *pipelinemanager.PipelineManager) func(w http.Respon } pm.Logger.Debugf("Homepath: %v\n", filepath.Dir(os.Args[0])) - pm.Logger.Debugf("Got start request object from container %#v\n", startReq.Info.ContainerName) + pm.Logger.Infof("Got start request object from container %#v\n", startReq.Info.ContainerName) pm.Logger.Debugf("Got a container with the following labels: %#v\n", startReq.Info.ContainerLabels) pm.Logger.Debugf("Got a container with the following log opts: %#v\n", startReq.Info.Config) @@ -64,13 +64,13 @@ func stopLoggingHandler(pm *pipelinemanager.PipelineManager) func(w http.Respons http.Error(w, errors.Wrap(err, "error decoding json request").Error(), http.StatusBadRequest) return } - pm.Logger.Infof(" Got stop request object %#v\n", stopReq) + pm.Logger.Infof("Got stop request object %#v\n", stopReq) // Run the stop async, since nothing 'depends' on it, // and we can break people's docker automation if this times out. go func() { err = pm.CloseClientWithFile(stopReq.File) if err != nil { - pm.Logger.Infof(" Got stop request error %#v\n", err) + pm.Logger.Errorf(" Got stop request error %#v\n", err) } }() diff --git a/x-pack/dockerlogbeat/magefile.go b/x-pack/dockerlogbeat/magefile.go index 977657742c6d..fb0ca9e15271 100644 --- a/x-pack/dockerlogbeat/magefile.go +++ b/x-pack/dockerlogbeat/magefile.go @@ -109,15 +109,15 @@ func createContainer(ctx context.Context, cli *client.Client) error { } //build, wait for output buildResp, err := cli.ImageBuild(ctx, buildContext, buildOpts) + if err != nil { + return errors.Wrap(err, "error building final container image") + } defer buildResp.Body.Close() - buf, errBufRead := ioutil.ReadAll(buildResp.Body) + // This blocks until the build operation completes + _, errBufRead := ioutil.ReadAll(buildResp.Body) if errBufRead != nil { return errors.Wrap(err, "error reading from docker output") } - if err != nil { - fmt.Printf("Docker response: \n %s\n", string(buf)) - return errors.Wrap(err, "error building final container image") - } // move back to the x-pack dir err = os.Chdir(dockerLogBeatDir) diff --git a/x-pack/dockerlogbeat/main.go b/x-pack/dockerlogbeat/main.go index d763126f2dc2..60dcf70537f0 100644 --- a/x-pack/dockerlogbeat/main.go +++ b/x-pack/dockerlogbeat/main.go @@ -26,8 +26,12 @@ import ( // genNewMonitoringConfig is a hacked-in function to enable a debug stderr logger func genNewMonitoringConfig() (*common.Config, error) { + lvl, isSet := os.LookupEnv("LOG_DRIVER_LEVEL") + if !isSet { + lvl = "info" + } cfgObject := make(map[string]string) - cfgObject["level"] = "debug" + cfgObject["level"] = lvl cfgObject["to_stderr"] = "true" cfg, err := common.NewConfigFrom(cfgObject) diff --git a/x-pack/dockerlogbeat/pipelinemanager/libbeattools.go b/x-pack/dockerlogbeat/pipelinemanager/libbeattools.go index f4db79155d52..8f1e55f342e5 100644 --- a/x-pack/dockerlogbeat/pipelinemanager/libbeattools.go +++ b/x-pack/dockerlogbeat/pipelinemanager/libbeattools.go @@ -245,21 +245,21 @@ func loadMeta(metaPath string) (uuid.UUID, error) { func openRegular(filename string) (*os.File, error) { f, err := os.Open(filename) if err != nil { - return f, errors.Wrapf(err, "error opening file %s", filename) + return f, err } info, err := f.Stat() if err != nil { f.Close() - return nil, errors.Wrapf(err, "error statting %s", filename) + return nil, err } if !info.Mode().IsRegular() { f.Close() if info.IsDir() { - return nil, fmt.Errorf("%s is a directory", filename) + return nil, err } - return nil, fmt.Errorf("%s is not a regular file", filename) + return nil, err } return f, nil diff --git a/x-pack/dockerlogbeat/pipelinemanager/pipelineManager.go b/x-pack/dockerlogbeat/pipelinemanager/pipelineManager.go index d0df1dba5d2f..37696101e7c9 100644 --- a/x-pack/dockerlogbeat/pipelinemanager/pipelineManager.go +++ b/x-pack/dockerlogbeat/pipelinemanager/pipelineManager.go @@ -43,8 +43,7 @@ type PipelineManager struct { // NewPipelineManager creates a new Pipeline map func NewPipelineManager(logCfg *common.Config) *PipelineManager { return &PipelineManager{ - Logger: logp.NewLogger("PipelineManager"), - //mu: new(sync.Mutex), + Logger: logp.NewLogger("PipelineManager"), pipelines: make(map[string]*Pipeline), clients: make(map[string]*ClientLogger), }