From 5bc1573cc450963e93665370c39b17638b0d8b0c Mon Sep 17 00:00:00 2001 From: matt durham Date: Tue, 3 Oct 2023 09:30:15 -0400 Subject: [PATCH] Allow the passing in of enabled collectors. --- collector/collector.go | 9 ++++----- node_exporter.go | 2 +- 2 files changed, 5 insertions(+), 6 deletions(-) diff --git a/collector/collector.go b/collector/collector.go index 5019d65276..9f756588b4 100644 --- a/collector/collector.go +++ b/collector/collector.go @@ -58,7 +58,7 @@ var ( forcedCollectors = map[string]bool{} // collectors which have been explicitly enabled or disabled ) -func getDefaults() map[string]bool { +func GetDefaults() map[string]bool { defaults := make(map[string]bool) for k, v := range collectorStateGlobal { defaults[k] = *v @@ -118,11 +118,10 @@ func collectorFlagAction(collector string) func(ctx *kingpin.ParseContext) error } // NewNodeCollector creates a new NodeCollector. -func NewNodeCollector(config *NodeCollectorConfig, logger log.Logger, filters ...string) (*NodeCollector, error) { +func NewNodeCollector(config *NodeCollectorConfig, enabledCollectors map[string]bool, logger log.Logger, filters ...string) (*NodeCollector, error) { f := make(map[string]bool) - defaults := getDefaults() for _, filter := range filters { - enabled, exist := defaults[filter] + enabled, exist := enabledCollectors[filter] if !exist { return nil, fmt.Errorf("missing collector: %s", filter) } @@ -134,7 +133,7 @@ func NewNodeCollector(config *NodeCollectorConfig, logger log.Logger, filters .. collectors := make(map[string]Collector) initiatedCollectorsMtx.Lock() defer initiatedCollectorsMtx.Unlock() - for key, enabled := range defaults { + for key, enabled := range enabledCollectors { if !enabled || (len(f) > 0 && !f[key]) { continue } diff --git a/node_exporter.go b/node_exporter.go index 985d1b61db..74aa067188 100644 --- a/node_exporter.go +++ b/node_exporter.go @@ -102,7 +102,7 @@ func (h *handler) ServeHTTP(w http.ResponseWriter, r *http.Request) { // (in which case it will log all the collectors enabled via command-line // flags). func (h *handler) innerHandler(filters ...string) (http.Handler, error) { - nc, err := collector.NewNodeCollector(h.collectorConfig, h.logger, filters...) + nc, err := collector.NewNodeCollector(h.collectorConfig, collector.GetDefaults(), h.logger, filters...) if err != nil { return nil, fmt.Errorf("couldn't create collector: %s", err) }