From 7754a0b071844bc63e076e0031345894e3eea010 Mon Sep 17 00:00:00 2001 From: "mergify[bot]" <37929162+mergify[bot]@users.noreply.github.com> Date: Mon, 30 Sep 2024 07:37:47 +0200 Subject: [PATCH] [8.15](backport #40968) Restore docker.network.in.* and docker.network.out.* fields in docker module (#41025) * Restore docker.network.in.* and docker.network.out.* fields in docker module (#40968) * Restore docker.network.in.* and docker.network.out.* fields in docker module * Update CHANGELOG.next.asciidoc * Change git email * Trigger tests * Add pre-commit step to beats pipelines (#40560) Added pre-commit check to beats pipelines to validate if no merge-conflicts exist * Remove extra punctuation in some fields description --------- Co-authored-by: Olga Naydyonock (cherry picked from commit fc17d84f0050a2d2bae0a61a7f2134f09cec683e) * Update CHANGELOG.next.asciidoc --------- Co-authored-by: Michael Katsoulis Co-authored-by: Pierre HILBERT --- CHANGELOG.next.asciidoc | 1 + metricbeat/docs/fields.asciidoc | 98 +++++++++++++++++++ metricbeat/module/docker/fields.go | 2 +- .../module/docker/network/_meta/fields.yml | 44 +++++++++ metricbeat/module/docker/network/data.go | 12 +++ metricbeat/module/docker/network/helper.go | 11 +-- 6 files changed, 159 insertions(+), 9 deletions(-) diff --git a/CHANGELOG.next.asciidoc b/CHANGELOG.next.asciidoc index a7174371f21..a70c4433a2b 100644 --- a/CHANGELOG.next.asciidoc +++ b/CHANGELOG.next.asciidoc @@ -202,6 +202,7 @@ https://github.com/elastic/beats/compare/v8.8.1\...main[Check the HEAD diff] - Add new memory/cgroup metrics to Kibana module {pull}37232[37232] - Add SSL support to mysql module {pull}37997[37997] - Add SSL support for aerospike module {pull}38126[38126] +- Restore docker.network.in.* and docker.network.out.* fields in docker module {pull}40968[40968] *Metricbeat* diff --git a/metricbeat/docs/fields.asciidoc b/metricbeat/docs/fields.asciidoc index 16842879e41..a8dce12684c 100644 --- a/metricbeat/docs/fields.asciidoc +++ b/metricbeat/docs/fields.asciidoc @@ -14500,6 +14500,104 @@ type: keyword -- +[float] +=== in + +Incoming network stats per second. + + + +*`docker.network.in.bytes`*:: ++ +-- +Incoming bytes per seconds. + + +type: long + +format: bytes + +-- + +*`docker.network.in.dropped`*:: ++ +-- +Dropped incoming packets per second. + + +type: scaled_float + +-- + +*`docker.network.in.errors`*:: ++ +-- +Errors on incoming packets per second. + + +type: long + +-- + +*`docker.network.in.packets`*:: ++ +-- +Incoming packets per second. + + +type: long + +-- + +[float] +=== out + +Outgoing network stats per second. + + + +*`docker.network.out.bytes`*:: ++ +-- +Outgoing bytes per second. + + +type: long + +format: bytes + +-- + +*`docker.network.out.dropped`*:: ++ +-- +Dropped outgoing packets per second. + + +type: scaled_float + +-- + +*`docker.network.out.errors`*:: ++ +-- +Errors on outgoing packets per second. + + +type: long + +-- + +*`docker.network.out.packets`*:: ++ +-- +Outgoing packets per second. + + +type: long + +-- + [float] === inbound diff --git a/metricbeat/module/docker/fields.go b/metricbeat/module/docker/fields.go index 9c88da1e5b9..a313e328ed9 100644 --- a/metricbeat/module/docker/fields.go +++ b/metricbeat/module/docker/fields.go @@ -32,5 +32,5 @@ func init() { // AssetDocker returns asset data. // This is the base64 encoded zlib format compressed contents of module/docker. func AssetDocker() string { - return "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" + return "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" } diff --git a/metricbeat/module/docker/network/_meta/fields.yml b/metricbeat/module/docker/network/_meta/fields.yml index 68af440a9bf..b931e6a89f6 100644 --- a/metricbeat/module/docker/network/_meta/fields.yml +++ b/metricbeat/module/docker/network/_meta/fields.yml @@ -9,6 +9,50 @@ type: keyword description: > Network interface name. + - name: in + type: group + description: > + Incoming network stats per second. + fields: + - name: bytes + type: long + format: bytes + description: > + Incoming bytes per seconds. + - name: dropped + type: scaled_float + description: > + Dropped incoming packets per second. + - name: errors + type: long + description: > + Errors on incoming packets per second. + - name: packets + type: long + description: > + Incoming packets per second. + - name: out + type: group + description: > + Outgoing network stats per second. + fields: + - name: bytes + type: long + format: bytes + description: > + Outgoing bytes per second. + - name: dropped + type: scaled_float + description: > + Dropped outgoing packets per second. + - name: errors + type: long + description: > + Errors on outgoing packets per second. + - name: packets + type: long + description: > + Outgoing packets per second. - name: inbound type: group description: > diff --git a/metricbeat/module/docker/network/data.go b/metricbeat/module/docker/network/data.go index 823b226d0f9..736a19553ab 100644 --- a/metricbeat/module/docker/network/data.go +++ b/metricbeat/module/docker/network/data.go @@ -37,6 +37,18 @@ func eventMapping(r mb.ReporterV2, stats *NetStats) { RootFields: rootFields, MetricSetFields: mapstr.M{ "interface": stats.NameInterface, + "in": mapstr.M{ + "bytes": stats.RxBytes, + "dropped": stats.RxDropped, + "errors": stats.RxErrors, + "packets": stats.RxPackets, + }, + "out": mapstr.M{ + "bytes": stats.TxBytes, + "dropped": stats.TxDropped, + "errors": stats.TxErrors, + "packets": stats.TxPackets, + }, "inbound": mapstr.M{ "bytes": stats.Total.RxBytes, "dropped": stats.Total.RxDropped, diff --git a/metricbeat/module/docker/network/helper.go b/metricbeat/module/docker/network/helper.go index 0f980fc2ab9..b5ab0a626b7 100644 --- a/metricbeat/module/docker/network/helper.go +++ b/metricbeat/module/docker/network/helper.go @@ -99,7 +99,9 @@ func (n *NetService) getNetworkStats(nameInterface string, rawNetStats types.Net netStats.TxErrors = n.getTxErrorsPerSecond(&newNetworkStats, &oldNetworkStat) netStats.TxPackets = n.getTxPacketsPerSecond(&newNetworkStats, &oldNetworkStat) } else { - n.NetworkStatPerContainer[myRawstats.Container.ID] = make(map[string]NetRaw) + if _, conExists := n.NetworkStatPerContainer[myRawstats.Container.ID]; !conExists { + n.NetworkStatPerContainer[myRawstats.Container.ID] = make(map[string]NetRaw) + } } n.NetworkStatPerContainer[myRawstats.Container.ID][nameInterface] = newNetworkStats @@ -121,13 +123,6 @@ func createNetRaw(time time.Time, stats *types.NetworkStats) NetRaw { } } -func (n *NetService) checkStats(containerID string, nameInterface string) bool { - if _, exist := n.NetworkStatPerContainer[containerID][nameInterface]; exist { - return true - } - return false -} - func (n *NetService) getRxBytesPerSecond(newStats *NetRaw, oldStats *NetRaw) float64 { duration := newStats.Time.Sub(oldStats.Time) return n.calculatePerSecond(duration, oldStats.RxBytes, newStats.RxBytes)