mirror of
https://github.com/matrix-org/dendrite.git
synced 2026-01-16 18:43:10 -06:00
Add runtime tracing
This commit is contained in:
parent
56b28b01db
commit
679ee11032
|
|
@ -21,12 +21,12 @@ import (
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
"net/http/httputil"
|
"net/http/httputil"
|
||||||
"os"
|
"os"
|
||||||
|
"runtime/trace"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/getsentry/sentry-go"
|
"github.com/getsentry/sentry-go"
|
||||||
"github.com/matrix-org/util"
|
"github.com/matrix-org/util"
|
||||||
"github.com/opentracing/opentracing-go"
|
"github.com/opentracing/opentracing-go"
|
||||||
"github.com/opentracing/opentracing-go/ext"
|
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
"github.com/prometheus/client_golang/prometheus/promauto"
|
"github.com/prometheus/client_golang/prometheus/promauto"
|
||||||
"github.com/prometheus/client_golang/prometheus/promhttp"
|
"github.com/prometheus/client_golang/prometheus/promhttp"
|
||||||
|
|
@ -186,9 +186,11 @@ func MakeExternalAPI(metricsName string, f func(*http.Request) util.JSONResponse
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ctx, task := trace.NewTask(req.Context(), metricsName)
|
||||||
|
defer task.End()
|
||||||
span := opentracing.StartSpan(metricsName)
|
span := opentracing.StartSpan(metricsName)
|
||||||
defer span.Finish()
|
defer span.Finish()
|
||||||
req = req.WithContext(opentracing.ContextWithSpan(req.Context(), span))
|
req = req.WithContext(opentracing.ContextWithSpan(ctx, span))
|
||||||
h.ServeHTTP(nextWriter, req)
|
h.ServeHTTP(nextWriter, req)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
@ -223,57 +225,6 @@ func MakeHTMLAPI(metricsName string, enableMetrics bool, f func(http.ResponseWri
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
// MakeInternalAPI turns a util.JSONRequestHandler function into an http.Handler.
|
|
||||||
// This is used for APIs that are internal to dendrite.
|
|
||||||
// If we are passed a tracing context in the request headers then we use that
|
|
||||||
// as the parent of any tracing spans we create.
|
|
||||||
func MakeInternalAPI(metricsName string, enableMetrics bool, f func(*http.Request) util.JSONResponse) http.Handler {
|
|
||||||
h := util.MakeJSONAPI(util.NewJSONRequestHandler(f))
|
|
||||||
withSpan := func(w http.ResponseWriter, req *http.Request) {
|
|
||||||
carrier := opentracing.HTTPHeadersCarrier(req.Header)
|
|
||||||
tracer := opentracing.GlobalTracer()
|
|
||||||
clientContext, err := tracer.Extract(opentracing.HTTPHeaders, carrier)
|
|
||||||
var span opentracing.Span
|
|
||||||
if err == nil {
|
|
||||||
// Default to a span without RPC context.
|
|
||||||
span = tracer.StartSpan(metricsName)
|
|
||||||
} else {
|
|
||||||
// Set the RPC context.
|
|
||||||
span = tracer.StartSpan(metricsName, ext.RPCServerOption(clientContext))
|
|
||||||
}
|
|
||||||
defer span.Finish()
|
|
||||||
req = req.WithContext(opentracing.ContextWithSpan(req.Context(), span))
|
|
||||||
h.ServeHTTP(w, req)
|
|
||||||
}
|
|
||||||
|
|
||||||
if !enableMetrics {
|
|
||||||
return http.HandlerFunc(withSpan)
|
|
||||||
}
|
|
||||||
|
|
||||||
return promhttp.InstrumentHandlerCounter(
|
|
||||||
promauto.NewCounterVec(
|
|
||||||
prometheus.CounterOpts{
|
|
||||||
Name: metricsName + "_requests_total",
|
|
||||||
Help: "Total number of internal API calls",
|
|
||||||
Namespace: "dendrite",
|
|
||||||
},
|
|
||||||
[]string{"code"},
|
|
||||||
),
|
|
||||||
promhttp.InstrumentHandlerResponseSize(
|
|
||||||
promauto.NewHistogramVec(
|
|
||||||
prometheus.HistogramOpts{
|
|
||||||
Namespace: "dendrite",
|
|
||||||
Name: metricsName + "_response_size_bytes",
|
|
||||||
Help: "A histogram of response sizes for requests.",
|
|
||||||
Buckets: []float64{200, 500, 900, 1500, 5000, 15000, 50000, 100000},
|
|
||||||
},
|
|
||||||
[]string{},
|
|
||||||
),
|
|
||||||
http.HandlerFunc(withSpan),
|
|
||||||
),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
// WrapHandlerInBasicAuth adds basic auth to a handler. Only used for /metrics
|
// WrapHandlerInBasicAuth adds basic auth to a handler. Only used for /metrics
|
||||||
func WrapHandlerInBasicAuth(h http.Handler, b BasicAuth) http.HandlerFunc {
|
func WrapHandlerInBasicAuth(h http.Handler, b BasicAuth) http.HandlerFunc {
|
||||||
if b.Username == "" || b.Password == "" {
|
if b.Username == "" || b.Password == "" {
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue