summaryrefslogtreecommitdiffhomepage
path: root/modules/metrics/adminmetrics.go
diff options
context:
space:
mode:
authorMohammed Al Sahaf <[email protected]>2024-10-02 17:23:26 +0300
committerGitHub <[email protected]>2024-10-02 08:23:26 -0600
commit41f5dd56e1b93ec815daa98dd1f1caa7f2087312 (patch)
tree4802459d6c89d6cbaf064d02b445130fa361b12d /modules/metrics/adminmetrics.go
parent16724842d9b9096b800326d0b7667a4361552552 (diff)
downloadcaddy-41f5dd56e1b93ec815daa98dd1f1caa7f2087312.tar.gz
caddy-41f5dd56e1b93ec815daa98dd1f1caa7f2087312.zip
metrics: scope metrics to active config, add optional per-host metrics (#6531)v2.9.0-beta.1
* Add per host config * Pass host label when option is enabled * Test per host enabled * metrics: scope metrics per loaded config * doc and linter Signed-off-by: Mohammed Al Sahaf <[email protected]> * inject the custom registry into the admin handler Co-Authored-By: Dave Henderson <[email protected]> * remove `TODO` comment * fixes Signed-off-by: Mohammed Al Sahaf <[email protected]> * refactor to delay metrics admin handler provision Signed-off-by: Mohammed Al Sahaf <[email protected]> --------- Signed-off-by: Mohammed Al Sahaf <[email protected]> Co-authored-by: Hussam Almarzooq <[email protected]> Co-authored-by: Dave Henderson <[email protected]>
Diffstat (limited to 'modules/metrics/adminmetrics.go')
-rw-r--r--modules/metrics/adminmetrics.go32
1 files changed, 25 insertions, 7 deletions
diff --git a/modules/metrics/adminmetrics.go b/modules/metrics/adminmetrics.go
index 1cf398e4c..1e3a841dd 100644
--- a/modules/metrics/adminmetrics.go
+++ b/modules/metrics/adminmetrics.go
@@ -15,8 +15,11 @@
package metrics
import (
+ "errors"
"net/http"
+ "github.com/prometheus/client_golang/prometheus"
+
"github.com/caddyserver/caddy/v2"
)
@@ -29,7 +32,11 @@ func init() {
// is permanently mounted to the admin API endpoint at "/metrics".
// See the Metrics module for a configurable endpoint that is usable if the
// Admin API is disabled.
-type AdminMetrics struct{}
+type AdminMetrics struct {
+ registry *prometheus.Registry
+
+ metricsHandler http.Handler
+}
// CaddyModule returns the Caddy module information.
func (AdminMetrics) CaddyModule() caddy.ModuleInfo {
@@ -39,17 +46,28 @@ func (AdminMetrics) CaddyModule() caddy.ModuleInfo {
}
}
+// Provision -
+func (m *AdminMetrics) Provision(ctx caddy.Context) error {
+ m.registry = ctx.GetMetricsRegistry()
+ if m.registry == nil {
+ return errors.New("no metrics registry found")
+ }
+ m.metricsHandler = createMetricsHandler(nil, false, m.registry)
+ return nil
+}
+
// Routes returns a route for the /metrics endpoint.
func (m *AdminMetrics) Routes() []caddy.AdminRoute {
- metricsHandler := createMetricsHandler(nil, false)
- h := caddy.AdminHandlerFunc(func(w http.ResponseWriter, r *http.Request) error {
- metricsHandler.ServeHTTP(w, r)
- return nil
- })
- return []caddy.AdminRoute{{Pattern: "/metrics", Handler: h}}
+ return []caddy.AdminRoute{{Pattern: "/metrics", Handler: caddy.AdminHandlerFunc(m.serveHTTP)}}
+}
+
+func (m *AdminMetrics) serveHTTP(w http.ResponseWriter, r *http.Request) error {
+ m.metricsHandler.ServeHTTP(w, r)
+ return nil
}
// Interface guards
var (
+ _ caddy.Provisioner = (*AdminMetrics)(nil)
_ caddy.AdminRouter = (*AdminMetrics)(nil)
)