Skip to content

Commit

Permalink
Pass host label when option is enabled
Browse files Browse the repository at this point in the history
  • Loading branch information
hussam-almarzoq committed May 1, 2024
1 parent 368b156 commit 56685f7
Showing 1 changed file with 18 additions and 6 deletions.
24 changes: 18 additions & 6 deletions modules/caddyhttp/metrics.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,10 +32,13 @@ var httpMetrics = struct {
init: sync.Once{},
}

func initHTTPMetrics() {
func initHTTPMetrics(perHost bool) {
const ns, sub = "caddy", "http"

basicLabels := []string{"server", "handler"}
if perHost {
basicLabels = append(basicLabels, "host")
}
httpMetrics.requestInFlight = promauto.NewGaugeVec(prometheus.GaugeOpts{
Namespace: ns,
Subsystem: sub,
Expand All @@ -60,6 +63,9 @@ func initHTTPMetrics() {
sizeBuckets := prometheus.ExponentialBuckets(256, 4, 8)

httpLabels := []string{"server", "handler", "code", "method"}
if perHost {
httpLabels = append(httpLabels, "host")
}
httpMetrics.requestDuration = promauto.NewHistogramVec(prometheus.HistogramOpts{
Namespace: ns,
Subsystem: sub,
Expand Down Expand Up @@ -103,23 +109,29 @@ func serverNameFromContext(ctx context.Context) string {
type metricsInstrumentedHandler struct {
handler string
mh MiddlewareHandler
perHost bool
}

func newMetricsInstrumentedHandler(handler string, mh MiddlewareHandler) *metricsInstrumentedHandler {
func newMetricsInstrumentedHandler(handler string, mh MiddlewareHandler, perHost bool) *metricsInstrumentedHandler {
httpMetrics.init.Do(func() {
initHTTPMetrics()
initHTTPMetrics(perHost)
})

return &metricsInstrumentedHandler{handler, mh}
return &metricsInstrumentedHandler{handler, mh, perHost}
}

func (h *metricsInstrumentedHandler) ServeHTTP(w http.ResponseWriter, r *http.Request, next Handler) error {
server := serverNameFromContext(r.Context())
labels := prometheus.Labels{"server": server, "handler": h.handler}
labels := prometheus.Labels{"server": server, "handler": h.handler, "host": host}
method := metrics.SanitizeMethod(r.Method)
// the "code" value is set later, but initialized here to eliminate the possibility
// of a panic
statusLabels := prometheus.Labels{"server": server, "handler": h.handler, "method": method, "code": ""}
statusLabels := prometheus.Labels{"server": server, "handler": h.handler, "host": host, "method": method, "code": ""}

if h.perHost {
labels["host"] = r.Host
statusLabels["host"] = r.Host
}

inFlight := httpMetrics.requestInFlight.With(labels)
inFlight.Inc()
Expand Down

0 comments on commit 56685f7

Please sign in to comment.