Skip to content

Commit

Permalink
Cherry-pick #10157 to 6.x: Add remaining memory metrics of pods in Ku…
Browse files Browse the repository at this point in the history
…bernetes metricbeat module (#10454)

(cherry picked from commit e14225c)

Co-authored-by: Vijay Samuel <[email protected]>
  • Loading branch information
jsoriano and vjsamuel authored Feb 2, 2019
1 parent 33217a6 commit c43ce99
Show file tree
Hide file tree
Showing 7 changed files with 114 additions and 5 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.next.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -211,6 +211,7 @@ https://github.com/elastic/beats/compare/v6.6.0...6.x[Check the HEAD diff]
- Release use of xpack.enabled: true flag in Elasticsearch and Kibana modules as GA. {pull}10222[10222]
- Making RabbitMQ Metricbeat module GA. {pull}10165[10165]
- Release Elastic stack modules (Elasticsearch, Logstash, and Kibana) as GA. {pull}10094[10094]
- Add remaining memory metrics of pods in Kubernetes metricbeat module {pull}10157[10157]
- Added 'server' Metricset to Zookeeper Metricbeat module {issue}8938[8938] {pull}10341[10341]

*Packetbeat*
Expand Down
59 changes: 59 additions & 0 deletions metricbeat/docs/fields.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -9096,6 +9096,65 @@ format: percentage
Memory usage as a percentage of the defined limit for the pod containers (or total node allocatable memory if unlimited)
--
*`kubernetes.pod.memory.available.bytes`*::
+
--
type: long
format: bytes
Total memory available
--
*`kubernetes.pod.memory.working_set.bytes`*::
+
--
type: long
format: bytes
Total working set memory
--
*`kubernetes.pod.memory.rss.bytes`*::
+
--
type: long
format: bytes
Total resident set size memory
--
*`kubernetes.pod.memory.page_faults`*::
+
--
type: long
Total page faults
--
*`kubernetes.pod.memory.major_page_faults`*::
+
--
type: long
Total major page faults
--
[float]
Expand Down
2 changes: 1 addition & 1 deletion metricbeat/module/kubernetes/event/event_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ package event
import (
"testing"

"github.com/ericchiang/k8s/apis/core/v1"
v1 "github.com/ericchiang/k8s/apis/core/v1"
k8s_io_apimachinery_pkg_apis_meta_v1 "github.com/ericchiang/k8s/apis/meta/v1"
"github.com/stretchr/testify/assert"

Expand Down
2 changes: 1 addition & 1 deletion metricbeat/module/kubernetes/fields.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

32 changes: 32 additions & 0 deletions metricbeat/module/kubernetes/pod/_meta/fields.yml
Original file line number Diff line number Diff line change
Expand Up @@ -78,3 +78,35 @@
format: percentage
description: >
Memory usage as a percentage of the defined limit for the pod containers (or total node allocatable memory if unlimited)
- name: available
type: group
fields:
- name: bytes
type: long
format: bytes
description: >
Total memory available
- name: working_set
type: group
fields:
- name: bytes
type: long
format: bytes
description: >
Total working set memory
- name: rss
type: group
fields:
- name: bytes
type: long
format: bytes
description: >
Total resident set size memory
- name: page_faults
type: long
description: >
Total page faults
- name: major_page_faults
type: long
description: >
Total major page faults
21 changes: 19 additions & 2 deletions metricbeat/module/kubernetes/pod/data.go
Original file line number Diff line number Diff line change
Expand Up @@ -33,20 +33,26 @@ func eventMapping(content []byte, perfMetrics *util.PerfMetricsCache) ([]common.
var summary kubernetes.Summary
err := json.Unmarshal(content, &summary)
if err != nil {
return nil, fmt.Errorf("Cannot unmarshal json response: %s", err)
return nil, fmt.Errorf("cannot unmarshal json response: %s", err)
}

node := summary.Node
nodeCores := perfMetrics.NodeCoresAllocatable.Get(node.NodeName)
nodeMem := perfMetrics.NodeMemAllocatable.Get(node.NodeName)
for _, pod := range summary.Pods {
var usageNanoCores, usageMem int64
var usageNanoCores, usageMem, availMem, rss, workingSet, pageFaults, majorPageFaults int64
var coresLimit, memLimit float64

for _, cont := range pod.Containers {
cuid := util.ContainerUID(pod.PodRef.Namespace, pod.PodRef.Name, cont.Name)
usageNanoCores += cont.CPU.UsageNanoCores
usageMem += cont.Memory.UsageBytes
availMem += cont.Memory.AvailableBytes
rss += cont.Memory.RssBytes
workingSet += cont.Memory.WorkingSetBytes
pageFaults += cont.Memory.PageFaults
majorPageFaults += cont.Memory.MajorPageFaults

coresLimit += perfMetrics.ContainerCoresLimit.GetWithDefault(cuid, nodeCores)
memLimit += perfMetrics.ContainerMemLimit.GetWithDefault(cuid, nodeMem)
}
Expand All @@ -70,6 +76,17 @@ func eventMapping(content []byte, perfMetrics *util.PerfMetricsCache) ([]common.
"usage": common.MapStr{
"bytes": usageMem,
},
"available": common.MapStr{
"bytes": availMem,
},
"working_set": common.MapStr{
"bytes": workingSet,
},
"rss": common.MapStr{
"bytes": rss,
},
"page_faults": pageFaults,
"major_page_faults": majorPageFaults,
},

"network": common.MapStr{
Expand Down
2 changes: 1 addition & 1 deletion metricbeat/module/kubernetes/util/kubernetes_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ package util
import (
"testing"

"github.com/ericchiang/k8s/apis/meta/v1"
v1 "github.com/ericchiang/k8s/apis/meta/v1"
"github.com/stretchr/testify/assert"

"github.com/elastic/beats/libbeat/common"
Expand Down

0 comments on commit c43ce99

Please sign in to comment.