metricbeat/module/docker/container/data.go (60 lines of code) (raw):

// Licensed to Elasticsearch B.V. under one or more contributor // license agreements. See the NOTICE file distributed with // this work for additional information regarding copyright // ownership. Elasticsearch B.V. licenses this file to you under // the Apache License, Version 2.0 (the "License"); you may // not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, // software distributed under the License is distributed on an // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY // KIND, either express or implied. See the License for the // specific language governing permissions and limitations // under the License. package container import ( "time" "github.com/docker/docker/api/types" "github.com/docker/docker/api/types/container" "github.com/elastic/beats/v7/libbeat/autodiscover/providers/kubernetes" "github.com/elastic/beats/v7/libbeat/common" "github.com/elastic/beats/v7/metricbeat/mb" "github.com/elastic/elastic-agent-autodiscover/docker" "github.com/elastic/elastic-agent-libs/logp" "github.com/elastic/elastic-agent-libs/mapstr" ) func eventsMapping(r mb.ReporterV2, containersList []container.Summary, dedot bool, logger *logp.Logger) { for i := range containersList { eventMapping(r, &containersList[i], dedot, logger) } } func eventMapping(r mb.ReporterV2, cont *container.Summary, dedot bool, logger *logp.Logger) { event := mapstr.M{ "container": mapstr.M{ "id": cont.ID, "image": mapstr.M{ "name": cont.Image, }, "name": docker.ExtractContainerName(cont.Names), "runtime": "docker", }, "docker": mapstr.M{ "container": mapstr.M{ "created": common.Time(time.Unix(cont.Created, 0)), "command": cont.Command, "ip_addresses": extractIPAddresses(cont.NetworkSettings), "size": mapstr.M{ "root_fs": cont.SizeRootFs, "rw": cont.SizeRw, }, "status": cont.Status, }, }, } labels := docker.DeDotLabels(cont.Labels, dedot) if len(labels) > 0 { kubernetes.ShouldPut(event, "docker.container.labels", labels, logger) } r.Event(mb.Event{ RootFields: event, }) } func extractIPAddresses(networks *types.SummaryNetworkSettings) []string { // Handle alternate platforms like VMWare's VIC that might not have this data. if networks == nil { return []string{} } ipAddresses := make([]string, 0, len(networks.Networks)) for _, network := range networks.Networks { if len(network.IPAddress) > 0 { ipAddresses = append(ipAddresses, network.IPAddress) } } return ipAddresses }