From 3d4e41387b4cf99730ce0364183faee119f82b77 Mon Sep 17 00:00:00 2001 From: Kakuya Ando Date: Wed, 21 Feb 2024 15:34:43 +0900 Subject: [PATCH 1/2] Add SNMPInflight metric (#1119) * Add SNMPInflight metric --------- Signed-off-by: Kakuya Ando Signed-off-by: Robert Bergman --- collector/collector.go | 3 +++ main.go | 7 +++++++ 2 files changed, 10 insertions(+) diff --git a/collector/collector.go b/collector/collector.go index cb1faed0..1b7337ac 100644 --- a/collector/collector.go +++ b/collector/collector.go @@ -275,6 +275,7 @@ type Metrics struct { SNMPDuration prometheus.Histogram SNMPPackets prometheus.Counter SNMPRetries prometheus.Counter + SNMPInflight prometheus.Gauge } type NamedModule struct { @@ -346,7 +347,9 @@ func (c Collector) collect(ch chan<- prometheus.Metric, logger log.Logger, clien ) start := time.Now() moduleLabel := prometheus.Labels{"module": module.name} + c.metrics.SNMPInflight.Inc() results, err := ScrapeTarget(client, c.target, c.auth, module.Module, logger, c.metrics) + c.metrics.SNMPInflight.Dec() if err != nil { level.Info(logger).Log("msg", "Error scraping target", "err", err) ch <- prometheus.NewInvalidMetric(prometheus.NewDesc("snmp_error", "Error scraping target", nil, moduleLabel), err) diff --git a/main.go b/main.go index 43193d18..72bdb2b9 100644 --- a/main.go +++ b/main.go @@ -267,6 +267,13 @@ func main() { Help: "Number of SNMP packet retries.", }, ), + SNMPInflight: promauto.NewGauge( + prometheus.GaugeOpts{ + Namespace: namespace, + Name: "request_in_flight", + Help: "Current number of SNMP scrapes being requested.", + }, + ), } http.Handle(*metricsPath, promhttp.Handler()) // Normal metrics endpoint for SNMP exporter itself. From dea039998ba4ac2c80dfcac5cf6ca4e34e446c88 Mon Sep 17 00:00:00 2001 From: Robert Bergman Date: Sat, 24 Feb 2024 15:01:37 -0800 Subject: [PATCH 2/2] change #1074 broke SNMPv3 by removing the lines that need to go in config.go after 155 and 171 respectively: usm.AuthenticationPassphrase = string(c.Password) and usm.PrivacyPassphrase = string(c.PrivPassword) after adding the back in to the code, I tried running with having variables set via environment and in the snmp.yml and both worked. without them I was getting the error: securityParameter.PrivacyPassphrase is required when a privacy protocol is specified Signed-off-by: Robert Bergman --- config/config.go | 2 ++ 1 file changed, 2 insertions(+) diff --git a/config/config.go b/config/config.go index a41f664a..3f60edef 100644 --- a/config/config.go +++ b/config/config.go @@ -153,6 +153,7 @@ func (c Auth) ConfigureSNMP(g *gosnmp.GoSNMP) { priv = true } if auth { + usm.AuthenticationPassphrase = string(c.Password) switch c.AuthProtocol { case "SHA": usm.AuthenticationProtocol = gosnmp.SHA @@ -169,6 +170,7 @@ func (c Auth) ConfigureSNMP(g *gosnmp.GoSNMP) { } } if priv { + usm.PrivacyPassphrase = string(c.PrivPassword) switch c.PrivProtocol { case "DES": usm.PrivacyProtocol = gosnmp.DES