Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Metricbeat][Kubernetes] Share watchers between metricsets #37332

Merged
merged 76 commits into from
Apr 3, 2024
Merged
Show file tree
Hide file tree
Changes from 67 commits
Commits
Show all changes
76 commits
Select commit Hold shift + click to select a range
fab1407
Share watchers between metricsets.
constanca-m Dec 7, 2023
888dfbe
update CHANGELOG-developer.next.asciidoc
constanca-m Dec 7, 2023
e56dc9a
fix lint error.
constanca-m Dec 7, 2023
5ebc1b3
- Remove getResourceMetadataWatchers
constanca-m Dec 7, 2023
7c62943
Merge branch 'main' into fix-multiple-watchers
constanca-m Dec 26, 2023
8dd0ad6
Move map initialization to kubernetes top level
constanca-m Dec 27, 2023
3e55e7b
Merge branch 'main' into fix-multiple-watchers
constanca-m Dec 27, 2023
15de770
Refactor function name and add comments
constanca-m Jan 8, 2024
c3f57c4
- Rename resourcesUsing
constanca-m Jan 26, 2024
81bc171
Use metricset to distinguish between the ones that are using which re…
constanca-m Jan 26, 2024
6696438
Merge branch 'main' into fix-multiple-watchers
constanca-m Jan 26, 2024
809a442
goimports
constanca-m Jan 26, 2024
b76e38d
run mage check and make update
constanca-m Jan 26, 2024
4cc8a47
Pass add resource metadata instead of whole config.
constanca-m Jan 29, 2024
ab475d1
Refactor watch options to include namespace only when necessary
constanca-m Jan 29, 2024
eac4bde
Revert createMetaGen - removed namespace
constanca-m Jan 29, 2024
13e33a0
Revert createMetaGen - removed namespace
constanca-m Jan 29, 2024
688c406
remove log library
constanca-m Jan 30, 2024
e9783e0
add enrichers to watchers.
constanca-m Feb 2, 2024
c8a41cd
Merge branch 'main' into fix-multiple-watchers
constanca-m Feb 2, 2024
8e66700
Add metadataEvents to watcher
constanca-m Feb 5, 2024
83ba2cb
Merge branch 'main' into fix-multiple-watchers
constanca-m Feb 5, 2024
0d248ff
Add metadataEvents to watcher
constanca-m Feb 6, 2024
2df0188
Add ids to metadataEvents instead of whole object
constanca-m Feb 6, 2024
8d556e4
Pass metadata.MetaGen and *metadata.Resource as parameters to enricher
constanca-m Feb 6, 2024
0b61c02
Merge branch 'main' into fix-multiple-watchers
constanca-m Feb 6, 2024
f1de117
- Save enrichers as map to avoid duplicates in list
constanca-m Feb 7, 2024
25d9b05
Merge branch 'main' into fix-multiple-watchers
constanca-m Feb 7, 2024
186032e
- Remove extras : and / on the resources names
constanca-m Feb 7, 2024
65beebe
Reuse accessor.GetNamespace() variable
constanca-m Feb 7, 2024
59a4295
Avoid concurrent goroutine when using handler functions
constanca-m Feb 8, 2024
5f736ac
Merge branch 'main' into fix-multiple-watchers
constanca-m Feb 8, 2024
abc0201
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
cb77cd8
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
3a67987
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
f2d65a4
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
1d1a142
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
992400e
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
563cce7
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
9170619
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
014d255
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
ed338f7
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
10bd3c3
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
8c05496
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
b55176a
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
d1506ba
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
68471b8
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
63cb59e
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
8be51ea
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
7aedbe8
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
a902efe
Update metricbeat/module/kubernetes/util/kubernetes.go
constanca-m Feb 8, 2024
dd8e32c
Merge branch 'main' into fix-multiple-watchers
constanca-m Feb 8, 2024
60e6556
run mage check and make update
constanca-m Feb 8, 2024
d9e030a
Merge branch 'main' into fix-multiple-watchers
constanca-m Feb 8, 2024
adfce46
adjust to node scope
constanca-m Feb 13, 2024
354cf73
Merge branch 'main' into fix-multiple-watchers
constanca-m Feb 13, 2024
15b673a
update current watcher to restart watcher
constanca-m Feb 14, 2024
57135c9
Update all watchers - current and extra - according to watcher options
constanca-m Feb 14, 2024
519e3fb
Update go.mod
constanca-m Feb 19, 2024
a888b88
Merge branch 'main' into fix-multiple-watchers
constanca-m Feb 19, 2024
74d51e2
Add geteventhandler to mockwatcher
constanca-m Feb 19, 2024
b51c873
update NOTICE.txt
constanca-m Feb 19, 2024
64ac188
update NOTICE.txt
constanca-m Feb 19, 2024
d41e837
Never restart extra watchers
MichaelKatsoulis Feb 22, 2024
8fcdfc2
Set resourceMetaWatcher as started
MichaelKatsoulis Feb 22, 2024
a7f709a
Add a markdown with detailed explanation of metadata enrichment
MichaelKatsoulis Mar 13, 2024
21f7503
Update metricbeat/module/kubernetes/util/enrichers.md
constanca-m Mar 25, 2024
07819eb
Update code comments and remove enrichers.md
MichaelKatsoulis Mar 27, 2024
8fa7599
Update go.mod
MichaelKatsoulis Mar 27, 2024
64815dc
Merge remote-tracking branch 'upstream/main' into fix-multiple-watchers
MichaelKatsoulis Mar 27, 2024
38d44f4
Update metricbeat/module/kubernetes/util/kubernetes.go
MichaelKatsoulis Mar 28, 2024
a586db9
Merge branch 'main' into fix-multiple-watchers
constanca-m Apr 2, 2024
53fd63a
Update go.mod and add comment about lock
constanca-m Apr 2, 2024
b012f02
Update comment about lock
constanca-m Apr 2, 2024
f9f6f0a
Merge branch 'main' into fix-multiple-watchers
constanca-m Apr 3, 2024
92c3d5b
mage check
constanca-m Apr 3, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions CHANGELOG-developer.next.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,7 @@ The list below covers the major changes between 7.0.0-rc2 and main only.

==== Added

- Update watchers to be shared between metricsets in Kubernetes module. {pull}37332[37332]
- Add new metricset in Kubernetes module, `state_namespace`. {pull}36406[36406]
- Add configuration for APM instrumentation and expose the tracer trough the Beat object. {pull}17938[17938]
- Make the behavior of clientWorker and netClientWorker consistent when error is returned from publisher pipeline
Expand Down
4 changes: 2 additions & 2 deletions NOTICE.txt
Original file line number Diff line number Diff line change
Expand Up @@ -12283,11 +12283,11 @@ various licenses:

--------------------------------------------------------------------------------
Dependency : github.com/elastic/elastic-agent-autodiscover
Version: v0.6.7
Version: v0.6.8
Licence type (autodetected): Apache-2.0
--------------------------------------------------------------------------------

Contents of probable licence file $GOMODCACHE/github.com/elastic/elastic-agent-autodiscover@v0.6.7/LICENSE:
Contents of probable licence file $GOMODCACHE/github.com/elastic/elastic-agent-autodiscover@v0.6.8/LICENSE:

Apache License
Version 2.0, January 2004
Expand Down
2 changes: 1 addition & 1 deletion go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -201,7 +201,7 @@ require (
github.com/awslabs/kinesis-aggregation/go/v2 v2.0.0-20220623125934-28468a6701b5
github.com/elastic/bayeux v1.0.5
github.com/elastic/ebpfevents v0.4.0
github.com/elastic/elastic-agent-autodiscover v0.6.7
github.com/elastic/elastic-agent-autodiscover v0.6.8
github.com/elastic/elastic-agent-libs v0.7.5
github.com/elastic/elastic-agent-shipper-client v0.5.1-0.20230228231646-f04347b666f3
github.com/elastic/elastic-agent-system-metrics v0.9.1
Expand Down
4 changes: 2 additions & 2 deletions go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -665,8 +665,8 @@ github.com/elastic/dhcp v0.0.0-20200227161230-57ec251c7eb3 h1:lnDkqiRFKm0rxdljqr
github.com/elastic/dhcp v0.0.0-20200227161230-57ec251c7eb3/go.mod h1:aPqzac6AYkipvp4hufTyMj5PDIphF3+At8zr7r51xjY=
github.com/elastic/ebpfevents v0.4.0 h1:M80eAeJnzvGQgU9cjJqkjFca9pjM3aq/TuZxJeom4bI=
github.com/elastic/ebpfevents v0.4.0/go.mod h1:o21z5xup/9dK8u0Hg9bZRflSqqj1Zu5h2dg2hSTcUPQ=
github.com/elastic/elastic-agent-autodiscover v0.6.7 h1:+KVjltN0rPsBrU8b156gV4lOTBgG/vt0efFCFARrf3g=
github.com/elastic/elastic-agent-autodiscover v0.6.7/go.mod h1:hFeFqneS2r4jD0/QzGkrNk0YVdN0JGh7lCWdsH7zcI4=
github.com/elastic/elastic-agent-autodiscover v0.6.8 h1:BSXz+QwjZAEt08G+T3GDGl14Bh9a6zD8luNCvZut/b8=
github.com/elastic/elastic-agent-autodiscover v0.6.8/go.mod h1:hFeFqneS2r4jD0/QzGkrNk0YVdN0JGh7lCWdsH7zcI4=
github.com/elastic/elastic-agent-client/v7 v7.8.0 h1:GHFzDJIWpdgI0qDk5EcqbQJGvwTsl2E2vQK3/xe+MYQ=
github.com/elastic/elastic-agent-client/v7 v7.8.0/go.mod h1:ihtjqJzYiIltlRhNruaSSc0ogxIhqPD5hOMKq16cI1s=
github.com/elastic/elastic-agent-libs v0.7.5 h1:4UMqB3BREvhwecYTs/L23oQp1hs/XUkcunPlmTZn5yg=
Expand Down
4 changes: 4 additions & 0 deletions libbeat/autodiscover/providers/kubernetes/pod_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -2150,6 +2150,10 @@ func (s *mockUpdaterWatcher) Store() caches.Store {
func (s *mockUpdaterWatcher) AddEventHandler(kubernetes.ResourceEventHandler) {
}

func (s *mockUpdaterWatcher) GetEventHandler() kubernetes.ResourceEventHandler {
return nil
}

func (s *mockUpdaterStore) List() []interface{} {
return s.objects
}
Expand Down
17 changes: 5 additions & 12 deletions metricbeat/helper/kubernetes/state_metricset.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,8 +29,6 @@ import (
k8smod "github.com/elastic/beats/v7/metricbeat/module/kubernetes"
)

const prefix = "state_"

/*
mappings stores the metrics for each metricset. The key of the map is the name of the metricset
and the values are the mapping of the metricset metrics.
Expand All @@ -45,7 +43,7 @@ var lock sync.RWMutex
// The New method will be called after the setup of the module and before starting to fetch data
func Init(name string, mapping *prometheus.MetricsMapping) {
if name != util.NamespaceResource {
name = prefix + name
name = util.StateMetricsetPrefix + name
}
lock.Lock()
mappings[name] = mapping
Expand Down Expand Up @@ -79,16 +77,11 @@ func New(base mb.BaseMetricSet) (mb.MetricSet, error) {
mapping := mappings[base.Name()]
lock.Unlock()

resourceName := base.Name()
if resourceName != util.NamespaceResource {
resourceName = strings.ReplaceAll(resourceName, prefix, "")
}

return &MetricSet{
BaseMetricSet: base,
prometheusClient: prometheusClient,
prometheusMapping: mapping,
enricher: util.NewResourceMetadataEnricher(base, resourceName, mod.GetMetricsRepo(), false),
enricher: util.NewResourceMetadataEnricher(base, mod.GetMetricsRepo(), mod.GetResourceWatchers(), false),
mod: mod,
}, nil
}
Expand All @@ -103,12 +96,12 @@ func (m *MetricSet) Fetch(reporter mb.ReporterV2) {
// for the state_namespace metricset.
resourceName := m.BaseMetricSet.Name()
if resourceName != util.NamespaceResource {
resourceName = strings.ReplaceAll(resourceName, prefix, "")
resourceName = strings.ReplaceAll(resourceName, util.StateMetricsetPrefix, "")
} else {
resourceName = "state_namespace"
}

m.enricher.Start()
m.enricher.Start(m.mod.GetResourceWatchers())

families, err := m.mod.GetStateMetricsFamilies(m.prometheusClient)
if err != nil {
Expand Down Expand Up @@ -139,6 +132,6 @@ func (m *MetricSet) Fetch(reporter mb.ReporterV2) {

// Close stops this metricset
func (m *MetricSet) Close() error {
m.enricher.Stop()
m.enricher.Stop(m.mod.GetResourceWatchers())
return nil
}
6 changes: 3 additions & 3 deletions metricbeat/module/kubernetes/container/container.go
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,7 @@ func New(base mb.BaseMetricSet) (mb.MetricSet, error) {
return &MetricSet{
BaseMetricSet: base,
http: http,
enricher: util.NewContainerMetadataEnricher(base, mod.GetMetricsRepo(), true),
enricher: util.NewContainerMetadataEnricher(base, mod.GetMetricsRepo(), mod.GetResourceWatchers(), true),
mod: mod,
}, nil
}
Expand All @@ -84,7 +84,7 @@ func New(base mb.BaseMetricSet) (mb.MetricSet, error) {
// format. It publishes the event which is then forwarded to the output. In case
// of an error set the Error field of mb.Event or simply call report.Error().
func (m *MetricSet) Fetch(reporter mb.ReporterV2) {
m.enricher.Start()
m.enricher.Start(m.mod.GetResourceWatchers())

body, err := m.mod.GetKubeletStats(m.http)
if err != nil {
Expand Down Expand Up @@ -131,6 +131,6 @@ func (m *MetricSet) Fetch(reporter mb.ReporterV2) {

// Close stops this metricset
func (m *MetricSet) Close() error {
m.enricher.Stop()
m.enricher.Stop(m.mod.GetResourceWatchers())
return nil
}
8 changes: 8 additions & 0 deletions metricbeat/module/kubernetes/kubernetes.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@ type Module interface {
GetStateMetricsFamilies(prometheus p.Prometheus) ([]*p.MetricFamily, error)
GetKubeletStats(http *helper.HTTP) ([]byte, error)
GetMetricsRepo() *util.MetricsRepo
GetResourceWatchers() *util.Watchers
}

type familiesCache struct {
Expand Down Expand Up @@ -86,6 +87,7 @@ type module struct {
kubeStateMetricsCache *kubeStateMetricsCache
kubeletStatsCache *kubeletStatsCache
metricsRepo *util.MetricsRepo
resourceWatchers *util.Watchers
cacheHash uint64
}

Expand All @@ -97,6 +99,7 @@ func ModuleBuilder() func(base mb.BaseModule) (mb.Module, error) {
cacheMap: make(map[uint64]*statsCache),
}
metricsRepo := util.NewMetricsRepo()
resourceWatchers := util.NewWatchers()
return func(base mb.BaseModule) (mb.Module, error) {
hash, err := generateCacheHash(base.Config().Hosts)
if err != nil {
Expand All @@ -108,6 +111,7 @@ func ModuleBuilder() func(base mb.BaseModule) (mb.Module, error) {
kubeStateMetricsCache: kubeStateMetricsCache,
kubeletStatsCache: kubeletStatsCache,
metricsRepo: metricsRepo,
resourceWatchers: resourceWatchers,
cacheHash: hash,
}
return &m, nil
Expand Down Expand Up @@ -162,3 +166,7 @@ func generateCacheHash(host []string) (uint64, error) {
func (m *module) GetMetricsRepo() *util.MetricsRepo {
return m.metricsRepo
}

func (m *module) GetResourceWatchers() *util.Watchers {
return m.resourceWatchers
}
6 changes: 3 additions & 3 deletions metricbeat/module/kubernetes/node/node.go
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,7 @@ func New(base mb.BaseMetricSet) (mb.MetricSet, error) {
return &MetricSet{
BaseMetricSet: base,
http: http,
enricher: util.NewResourceMetadataEnricher(base, util.NodeResource, mod.GetMetricsRepo(), false),
enricher: util.NewResourceMetadataEnricher(base, mod.GetMetricsRepo(), mod.GetResourceWatchers(), false),
mod: mod,
}, nil
}
Expand All @@ -84,7 +84,7 @@ func New(base mb.BaseMetricSet) (mb.MetricSet, error) {
// format. It publishes the event which is then forwarded to the output. In case
// of an error set the Error field of mb.Event or simply call report.Error().
func (m *MetricSet) Fetch(reporter mb.ReporterV2) {
m.enricher.Start()
m.enricher.Start(m.mod.GetResourceWatchers())

body, err := m.mod.GetKubeletStats(m.http)
if err != nil {
Expand Down Expand Up @@ -115,6 +115,6 @@ func (m *MetricSet) Fetch(reporter mb.ReporterV2) {

// Close stops this metricset
func (m *MetricSet) Close() error {
m.enricher.Stop()
m.enricher.Stop(m.mod.GetResourceWatchers())
return nil
}
6 changes: 3 additions & 3 deletions metricbeat/module/kubernetes/pod/pod.go
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ func New(base mb.BaseMetricSet) (mb.MetricSet, error) {
return &MetricSet{
BaseMetricSet: base,
http: http,
enricher: util.NewResourceMetadataEnricher(base, util.PodResource, mod.GetMetricsRepo(), true),
enricher: util.NewResourceMetadataEnricher(base, mod.GetMetricsRepo(), mod.GetResourceWatchers(), true),
mod: mod,
}, nil
}
Expand All @@ -85,7 +85,7 @@ func New(base mb.BaseMetricSet) (mb.MetricSet, error) {
// format. It publishes the event which is then forwarded to the output. In case
// of an error set the Error field of mb.Event or simply call report.Error().
func (m *MetricSet) Fetch(reporter mb.ReporterV2) {
m.enricher.Start()
m.enricher.Start(m.mod.GetResourceWatchers())

body, err := m.mod.GetKubeletStats(m.http)
if err != nil {
Expand Down Expand Up @@ -133,6 +133,6 @@ func (m *MetricSet) Fetch(reporter mb.ReporterV2) {

// Close stops this metricset
func (m *MetricSet) Close() error {
m.enricher.Stop()
m.enricher.Stop(m.mod.GetResourceWatchers())
return nil
}
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@ func New(base mb.BaseMetricSet) (mb.MetricSet, error) {
return &MetricSet{
BaseMetricSet: base,
prometheus: prometheus,
enricher: util.NewContainerMetadataEnricher(base, mod.GetMetricsRepo(), false),
enricher: util.NewContainerMetadataEnricher(base, mod.GetMetricsRepo(), mod.GetResourceWatchers(), false),
mod: mod,
}, nil
}
Expand All @@ -124,7 +124,7 @@ func New(base mb.BaseMetricSet) (mb.MetricSet, error) {
// format. It publishes the event which is then forwarded to the output. In case
// of an error set the Error field of mb.Event or simply call report.Error().
func (m *MetricSet) Fetch(reporter mb.ReporterV2) error {
m.enricher.Start()
m.enricher.Start(m.mod.GetResourceWatchers())

families, err := m.mod.GetStateMetricsFamilies(m.prometheus)
if err != nil {
Expand Down Expand Up @@ -196,6 +196,6 @@ func (m *MetricSet) Fetch(reporter mb.ReporterV2) error {

// Close stops this metricset
func (m *MetricSet) Close() error {
m.enricher.Stop()
m.enricher.Stop(m.mod.GetResourceWatchers())
return nil
}
Loading