From b65e970a83be8288adaef47ed9b6abee8df3601d Mon Sep 17 00:00:00 2001 From: Sergey Ponomarev Date: Tue, 17 Nov 2020 21:50:25 +0200 Subject: [PATCH] Improve docker events handling Firstly check health updates because it will be a lot of them especially when a container is unstable. Clearly handle create event to create a container even if it wasn't started. Instead of die event handle more precise events like oom, kill and only then trigger refresh. Lookup the state from a map. --- connector/docker.go | 29 +++++++++++++++++++++++++++-- 1 file changed, 27 insertions(+), 2 deletions(-) diff --git a/connector/docker.go b/connector/docker.go index 22f5758..a001791 100644 --- a/connector/docker.go +++ b/connector/docker.go @@ -14,6 +14,15 @@ import ( func init() { enabled["docker"] = NewDocker } +var actionToStatus = map[string]string{ + "create": "created", + "start": "running", + "kill": "exited", + "stop": "exited", + "pause": "paused", + "unpause": "running", +} + type Docker struct { client *api.Client containers map[string]*container.Container @@ -77,9 +86,16 @@ func (cm *Docker) watchEvents() { } switch actionName { - case "start", "die", "pause", "unpause", "health_status": + // most frequent event is a health checks + case "health_status": + healthStatus := e.Action[sepIdx+2:] if log.IsEnabledFor(logging.DEBUG) { - log.Debugf("handling docker event: action=%s id=%s", e.Action, e.ID) + log.Debugf("handling docker event: action=health_status id=%s %s", e.ID, healthStatus) + } + cm.needsRefresh <- e.ID + case "create": + if log.IsEnabledFor(logging.DEBUG) { + log.Debugf("handling docker event: action=create id=%s", e.ID) } cm.needsRefresh <- e.ID case "destroy": @@ -87,6 +103,15 @@ func (cm *Docker) watchEvents() { log.Debugf("handling docker event: action=destroy id=%s", e.ID) } cm.delByID(e.ID) + default: + // check if this action changes status e.g. start -> running + status := actionToStatus[actionName] + if status != "" { + if log.IsEnabledFor(logging.DEBUG) { + log.Debugf("handling docker event: action=%s id=%s %s", actionName, e.ID, status) + } + cm.needsRefresh <- e.ID + } } } log.Info("docker event listener exited")