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.
This commit is contained in:
Sergey Ponomarev 2020-11-17 21:50:25 +02:00
parent 957cabba2d
commit b65e970a83

View File

@ -14,6 +14,15 @@ import (
func init() { enabled["docker"] = NewDocker } 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 { type Docker struct {
client *api.Client client *api.Client
containers map[string]*container.Container containers map[string]*container.Container
@ -77,9 +86,16 @@ func (cm *Docker) watchEvents() {
} }
switch actionName { 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) { 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 cm.needsRefresh <- e.ID
case "destroy": case "destroy":
@ -87,6 +103,15 @@ func (cm *Docker) watchEvents() {
log.Debugf("handling docker event: action=destroy id=%s", e.ID) log.Debugf("handling docker event: action=destroy id=%s", e.ID)
} }
cm.delByID(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") log.Info("docker event listener exited")