diff --git a/CHANGELOG.asciidoc b/CHANGELOG.asciidoc index 11e8a3ac5290..e673dbcc7af0 100644 --- a/CHANGELOG.asciidoc +++ b/CHANGELOG.asciidoc @@ -238,6 +238,7 @@ https://github.com/elastic/beats/compare/v6.5.0...v7.0.0-alpha1[View commits] - Dissect will now flag event on parsing error. {pull}8751[8751] - add_cloud_metadata initialization is performed asynchronously to avoid delays on startup. {pull}8845[8845] - Added the `redirect_stderr` option that allows panics to be logged to log files. {pull}8430[8430] +- Add DeDot method in add_docker_metadata processor in libbeat. {issue}9350[9350] {pull}9505[9505] *Filebeat* diff --git a/auditbeat/auditbeat.reference.yml b/auditbeat/auditbeat.reference.yml index f69d819e615d..825466b4b3aa 100644 --- a/auditbeat/auditbeat.reference.yml +++ b/auditbeat/auditbeat.reference.yml @@ -291,6 +291,7 @@ auditbeat.modules: # match_source_index: 4 # match_short_id: false # cleanup_timeout: 60 +# labels.dedot: false # # To connect to Docker over TLS you must specify a client and CA certificate. # #ssl: # # certificate_authority: "/etc/pki/root/ca.pem" diff --git a/auditbeat/docs/getting-started.asciidoc b/auditbeat/docs/getting-started.asciidoc index 3373227d91c2..4e035527453f 100644 --- a/auditbeat/docs/getting-started.asciidoc +++ b/auditbeat/docs/getting-started.asciidoc @@ -97,6 +97,22 @@ endif::[] [[docker]] *docker:* +ifeval::["{release-state}"=="unreleased"] + +Version {stack-version} of {beatname_uc} has not yet been released. + +endif::[] + +ifeval::["{release-state}"!="unreleased"] + +["source","sh",subs="attributes"] +------------------------------------------------ +curl -L -O https://artifacts.elastic.co/downloads/beats/{beatname_lc}/{beatname_lc}-{version}-linux-x86_64.tar.gz +tar xzvf {beatname_lc}-{version}-linux-x86_64.tar.gz +------------------------------------------------ + +endif::[] + See <> for deploying Docker containers. [[win]] diff --git a/dev-tools/ecs-migration.yml b/dev-tools/ecs-migration.yml index c2ed53250ec9..d52e2a5a26a5 100644 --- a/dev-tools/ecs-migration.yml +++ b/dev-tools/ecs-migration.yml @@ -364,7 +364,7 @@ to: user_agent.original alias: true - # Note: `http` is not officially in ECS yet +# Note: `http` is not officially in ECS yet - from: nginx.access.response_code to: http.response.status_code diff --git a/filebeat/filebeat.reference.yml b/filebeat/filebeat.reference.yml index 345fde6946dd..02971e608ac1 100644 --- a/filebeat/filebeat.reference.yml +++ b/filebeat/filebeat.reference.yml @@ -973,6 +973,7 @@ filebeat.inputs: # match_source_index: 4 # match_short_id: false # cleanup_timeout: 60 +# labels.dedot: false # # To connect to Docker over TLS you must specify a client and CA certificate. # #ssl: # # certificate_authority: "/etc/pki/root/ca.pem" diff --git a/heartbeat/heartbeat.reference.yml b/heartbeat/heartbeat.reference.yml index a5571143e09b..fd3d8bb8af98 100644 --- a/heartbeat/heartbeat.reference.yml +++ b/heartbeat/heartbeat.reference.yml @@ -424,6 +424,7 @@ heartbeat.scheduler: # match_source_index: 4 # match_short_id: false # cleanup_timeout: 60 +# labels.dedot: false # # To connect to Docker over TLS you must specify a client and CA certificate. # #ssl: # # certificate_authority: "/etc/pki/root/ca.pem" diff --git a/journalbeat/journalbeat.reference.yml b/journalbeat/journalbeat.reference.yml index 2e936bc1cd6f..b53113f516ef 100644 --- a/journalbeat/journalbeat.reference.yml +++ b/journalbeat/journalbeat.reference.yml @@ -225,6 +225,7 @@ journalbeat.inputs: # match_source_index: 4 # match_short_id: false # cleanup_timeout: 60 +# labels.dedot: false # # To connect to Docker over TLS you must specify a client and CA certificate. # #ssl: # # certificate_authority: "/etc/pki/root/ca.pem" diff --git a/libbeat/_meta/config.reference.yml b/libbeat/_meta/config.reference.yml index 3321ed51e9c7..fe458d66775d 100644 --- a/libbeat/_meta/config.reference.yml +++ b/libbeat/_meta/config.reference.yml @@ -179,6 +179,7 @@ # match_source_index: 4 # match_short_id: false # cleanup_timeout: 60 +# labels.dedot: false # # To connect to Docker over TLS you must specify a client and CA certificate. # #ssl: # # certificate_authority: "/etc/pki/root/ca.pem" diff --git a/libbeat/docs/processors-using.asciidoc b/libbeat/docs/processors-using.asciidoc index 9a0e31e8a02a..53baa0a25982 100644 --- a/libbeat/docs/processors-using.asciidoc +++ b/libbeat/docs/processors-using.asciidoc @@ -848,6 +848,7 @@ processors: #match_source_index: 4 #match_short_id: true #cleanup_timeout: 60 + #labels.dedot: false # To connect to Docker over TLS you must specify a client and CA certificate. #ssl: # certificate_authority: "/etc/pki/root/ca.pem" @@ -885,6 +886,9 @@ for container ID. It defaults to 4 to match `cleanup_timeout`:: (Optional) Time of inactivity to consider we can clean and forget metadata for a container, 60s by default. +`labels.dedot`:: (Optional) Default to be false. If set to true, replace dots in + labels with `_`. + [[add-host-metadata]] === Add Host metadata diff --git a/libbeat/processors/add_docker_metadata/add_docker_metadata.go b/libbeat/processors/add_docker_metadata/add_docker_metadata.go index a8059800f637..1623a7bb176e 100644 --- a/libbeat/processors/add_docker_metadata/add_docker_metadata.go +++ b/libbeat/processors/add_docker_metadata/add_docker_metadata.go @@ -60,6 +60,7 @@ type addDockerMetadata struct { pidFields []string // Field names that contain PIDs. cgroups *common.Cache // Cache of PID (int) to cgropus (map[string]string). hostFS string // Directory where /proc is found + dedot bool // If set to true, replace dots in labels with `_`. } func newDockerMetadataProcessor(cfg *common.Config) (processors.Processor, error) { @@ -103,6 +104,7 @@ func buildDockerMetadataProcessor(cfg *common.Config, watcherConstructor docker. sourceProcessor: sourceProcessor, pidFields: config.MatchPIDs, hostFS: config.HostFS, + dedot: config.DeDot, }, nil } @@ -174,7 +176,12 @@ func (d *addDockerMetadata) Run(event *beat.Event) (*beat.Event, error) { if len(container.Labels) > 0 { labels := common.MapStr{} for k, v := range container.Labels { - safemapstr.Put(labels, k, v) + if d.dedot { + label := common.DeDot(k) + labels.Put(label, v) + } else { + safemapstr.Put(labels, k, v) + } } meta.Put("container.labels", labels) } diff --git a/libbeat/processors/add_docker_metadata/add_docker_metadata_test.go b/libbeat/processors/add_docker_metadata/add_docker_metadata_test.go index 679e9eb372b1..b986d58c9472 100644 --- a/libbeat/processors/add_docker_metadata/add_docker_metadata_test.go +++ b/libbeat/processors/add_docker_metadata/add_docker_metadata_test.go @@ -149,6 +149,51 @@ func TestMatchContainer(t *testing.T) { }, result.Fields) } +func TestMatchContainerWithDedot(t *testing.T) { + testConfig, err := common.NewConfigFrom(map[string]interface{}{ + "match_fields": []string{"foo"}, + "labels.dedot": true, + }) + assert.NoError(t, err) + + p, err := buildDockerMetadataProcessor(testConfig, MockWatcherFactory( + map[string]*docker.Container{ + "container_id": &docker.Container{ + ID: "container_id", + Image: "image", + Name: "name", + Labels: map[string]string{ + "a.x": "1", + "b": "2", + "b.foo": "3", + }, + }, + })) + assert.NoError(t, err, "initializing add_docker_metadata processor") + + input := common.MapStr{ + "foo": "container_id", + } + result, err := p.Run(&beat.Event{Fields: input}) + assert.NoError(t, err, "processing an event") + + assert.EqualValues(t, common.MapStr{ + "docker": common.MapStr{ + "container": common.MapStr{ + "id": "container_id", + "image": "image", + "labels": common.MapStr{ + "a_x": "1", + "b": "2", + "b_foo": "3", + }, + "name": "name", + }, + }, + "foo": "container_id", + }, result.Fields) +} + func TestMatchSource(t *testing.T) { // Use defaults testConfig, err := common.NewConfigFrom(map[string]interface{}{}) diff --git a/libbeat/processors/add_docker_metadata/config.go b/libbeat/processors/add_docker_metadata/config.go index a88caa97d0cc..dc1a3d4fc898 100644 --- a/libbeat/processors/add_docker_metadata/config.go +++ b/libbeat/processors/add_docker_metadata/config.go @@ -33,6 +33,7 @@ type Config struct { SourceIndex int `config:"match_source_index"` // Index in the source path split by / to look for container ID. MatchPIDs []string `config:"match_pids"` // A list of fields containing process IDs (PIDs). HostFS string `config:"system.hostfs"` // Specifies the mount point of the host’s filesystem for use in monitoring a host from within a container. + DeDot bool `config:"labels.dedot"` // If set to true, replace dots in labels with `_`. // Annotations are kept after container is killed, until they haven't been // accessed for a full `cleanup_timeout`: @@ -45,5 +46,6 @@ func defaultConfig() Config { MatchSource: true, SourceIndex: 4, // Use 4 to match the CID in /var/lib/docker/containers//*.log. MatchPIDs: []string{"process.pid", "process.ppid"}, + DeDot: false, } } diff --git a/metricbeat/metricbeat.reference.yml b/metricbeat/metricbeat.reference.yml index bc8d641356e5..7aad00aaac97 100644 --- a/metricbeat/metricbeat.reference.yml +++ b/metricbeat/metricbeat.reference.yml @@ -864,6 +864,7 @@ metricbeat.modules: # match_source_index: 4 # match_short_id: false # cleanup_timeout: 60 +# labels.dedot: false # # To connect to Docker over TLS you must specify a client and CA certificate. # #ssl: # # certificate_authority: "/etc/pki/root/ca.pem" diff --git a/metricbeat/module/elasticsearch/node/_meta/data.json b/metricbeat/module/elasticsearch/node/_meta/data.json index 7daf87c12e52..fa04d1b75611 100644 --- a/metricbeat/module/elasticsearch/node/_meta/data.json +++ b/metricbeat/module/elasticsearch/node/_meta/data.json @@ -48,4 +48,4 @@ "service": { "name": "elasticsearch" } -} \ No newline at end of file +} diff --git a/packetbeat/packetbeat.reference.yml b/packetbeat/packetbeat.reference.yml index f67837cabb09..ad1b43fa4b68 100644 --- a/packetbeat/packetbeat.reference.yml +++ b/packetbeat/packetbeat.reference.yml @@ -668,6 +668,7 @@ packetbeat.protocols: # match_source_index: 4 # match_short_id: false # cleanup_timeout: 60 +# labels.dedot: false # # To connect to Docker over TLS you must specify a client and CA certificate. # #ssl: # # certificate_authority: "/etc/pki/root/ca.pem" diff --git a/winlogbeat/winlogbeat.reference.yml b/winlogbeat/winlogbeat.reference.yml index 449d2bed9267..d2487c225ec3 100644 --- a/winlogbeat/winlogbeat.reference.yml +++ b/winlogbeat/winlogbeat.reference.yml @@ -208,6 +208,7 @@ winlogbeat.event_logs: # match_source_index: 4 # match_short_id: false # cleanup_timeout: 60 +# labels.dedot: false # # To connect to Docker over TLS you must specify a client and CA certificate. # #ssl: # # certificate_authority: "/etc/pki/root/ca.pem" diff --git a/x-pack/filebeat/filebeat.reference.yml b/x-pack/filebeat/filebeat.reference.yml index a4163a9c3496..2bbbe8711fd7 100644 --- a/x-pack/filebeat/filebeat.reference.yml +++ b/x-pack/filebeat/filebeat.reference.yml @@ -1007,6 +1007,7 @@ filebeat.inputs: # match_source_index: 4 # match_short_id: false # cleanup_timeout: 60 +# labels.dedot: false # # To connect to Docker over TLS you must specify a client and CA certificate. # #ssl: # # certificate_authority: "/etc/pki/root/ca.pem" diff --git a/x-pack/functionbeat/functionbeat.reference.yml b/x-pack/functionbeat/functionbeat.reference.yml index 6ac195923d6a..65caa69cc84c 100644 --- a/x-pack/functionbeat/functionbeat.reference.yml +++ b/x-pack/functionbeat/functionbeat.reference.yml @@ -273,6 +273,7 @@ functionbeat.provider.aws.functions: # match_source_index: 4 # match_short_id: false # cleanup_timeout: 60 +# labels.dedot: false # # To connect to Docker over TLS you must specify a client and CA certificate. # #ssl: # # certificate_authority: "/etc/pki/root/ca.pem" diff --git a/x-pack/metricbeat/metricbeat.reference.yml b/x-pack/metricbeat/metricbeat.reference.yml index f6b7ce9cf927..1f8f1a05ba9c 100644 --- a/x-pack/metricbeat/metricbeat.reference.yml +++ b/x-pack/metricbeat/metricbeat.reference.yml @@ -872,6 +872,7 @@ metricbeat.modules: # match_source_index: 4 # match_short_id: false # cleanup_timeout: 60 +# labels.dedot: false # # To connect to Docker over TLS you must specify a client and CA certificate. # #ssl: # # certificate_authority: "/etc/pki/root/ca.pem"