aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTill <2353100+S7evinK@users.noreply.github.com>2023-03-13 16:45:14 +0100
committerGitHub <noreply@github.com>2023-03-13 16:45:14 +0100
commit232aef016c928fddd57ac84ff1c9827db4eb68df (patch)
treeb8563d9f4f6768915266cce07734025dd3f21adc
parent689b5ee72fe2ff6226c2afc5b209889f772f0819 (diff)
Add basic runtime tracing (#2996)
This allows us in almost all places to use regions to further trace down long running tasks. Also removes an unused function.
-rw-r--r--appservice/query/query.go10
-rw-r--r--internal/httputil/httpapi.go66
-rw-r--r--internal/pushgateway/client.go6
-rw-r--r--internal/tracing.go64
-rw-r--r--internal/tracing_test.go25
-rw-r--r--roomserver/internal/input/input_events.go17
-rw-r--r--roomserver/internal/input/input_latest_events.go14
-rw-r--r--roomserver/internal/input/input_membership.go9
-rw-r--r--roomserver/internal/input/input_missing.go48
-rw-r--r--roomserver/state/state.go86
10 files changed, 190 insertions, 155 deletions
diff --git a/appservice/query/query.go b/appservice/query/query.go
index 2348eab4..0466f81d 100644
--- a/appservice/query/query.go
+++ b/appservice/query/query.go
@@ -25,10 +25,10 @@ import (
"strings"
"sync"
- "github.com/opentracing/opentracing-go"
log "github.com/sirupsen/logrus"
"github.com/matrix-org/dendrite/appservice/api"
+ "github.com/matrix-org/dendrite/internal"
"github.com/matrix-org/dendrite/setup/config"
)
@@ -50,8 +50,8 @@ func (a *AppServiceQueryAPI) RoomAliasExists(
request *api.RoomAliasExistsRequest,
response *api.RoomAliasExistsResponse,
) error {
- span, ctx := opentracing.StartSpanFromContext(ctx, "ApplicationServiceRoomAlias")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "ApplicationServiceRoomAlias")
+ defer trace.EndRegion()
// Determine which application service should handle this request
for _, appservice := range a.Cfg.Derived.ApplicationServices {
@@ -117,8 +117,8 @@ func (a *AppServiceQueryAPI) UserIDExists(
request *api.UserIDExistsRequest,
response *api.UserIDExistsResponse,
) error {
- span, ctx := opentracing.StartSpanFromContext(ctx, "ApplicationServiceUserID")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "ApplicationServiceUserID")
+ defer trace.EndRegion()
// Determine which application service should handle this request
for _, appservice := range a.Cfg.Derived.ApplicationServices {
diff --git a/internal/httputil/httpapi.go b/internal/httputil/httpapi.go
index 37d144f4..289d1d2c 100644
--- a/internal/httputil/httpapi.go
+++ b/internal/httputil/httpapi.go
@@ -25,8 +25,6 @@ import (
"github.com/getsentry/sentry-go"
"github.com/matrix-org/util"
- "github.com/opentracing/opentracing-go"
- "github.com/opentracing/opentracing-go/ext"
"github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/client_golang/prometheus/promauto"
"github.com/prometheus/client_golang/prometheus/promhttp"
@@ -34,6 +32,7 @@ import (
"github.com/matrix-org/dendrite/clientapi/auth"
"github.com/matrix-org/dendrite/clientapi/jsonerror"
+ "github.com/matrix-org/dendrite/internal"
userapi "github.com/matrix-org/dendrite/userapi/api"
)
@@ -186,9 +185,9 @@ func MakeExternalAPI(metricsName string, f func(*http.Request) util.JSONResponse
}
}
- span := opentracing.StartSpan(metricsName)
- defer span.Finish()
- req = req.WithContext(opentracing.ContextWithSpan(req.Context(), span))
+ trace, ctx := internal.StartTask(req.Context(), metricsName)
+ defer trace.EndTask()
+ req = req.WithContext(ctx)
h.ServeHTTP(nextWriter, req)
}
@@ -200,9 +199,9 @@ func MakeExternalAPI(metricsName string, f func(*http.Request) util.JSONResponse
// This is used to serve HTML alongside JSON error messages
func MakeHTMLAPI(metricsName string, enableMetrics bool, f func(http.ResponseWriter, *http.Request)) http.Handler {
withSpan := func(w http.ResponseWriter, req *http.Request) {
- span := opentracing.StartSpan(metricsName)
- defer span.Finish()
- req = req.WithContext(opentracing.ContextWithSpan(req.Context(), span))
+ trace, ctx := internal.StartTask(req.Context(), metricsName)
+ defer trace.EndTask()
+ req = req.WithContext(ctx)
f(w, req)
}
@@ -223,57 +222,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
func WrapHandlerInBasicAuth(h http.Handler, b BasicAuth) http.HandlerFunc {
if b.Username == "" || b.Password == "" {
diff --git a/internal/pushgateway/client.go b/internal/pushgateway/client.go
index 259239b8..d5671be3 100644
--- a/internal/pushgateway/client.go
+++ b/internal/pushgateway/client.go
@@ -10,8 +10,6 @@ import (
"time"
"github.com/matrix-org/dendrite/internal"
-
- "github.com/opentracing/opentracing-go"
)
type httpClient struct {
@@ -34,8 +32,8 @@ func NewHTTPClient(disableTLSValidation bool) Client {
}
func (h *httpClient) Notify(ctx context.Context, url string, req *NotifyRequest, resp *NotifyResponse) error {
- span, ctx := opentracing.StartSpanFromContext(ctx, "Notify")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "Notify")
+ defer trace.EndRegion()
body, err := json.Marshal(req)
if err != nil {
diff --git a/internal/tracing.go b/internal/tracing.go
new file mode 100644
index 00000000..4e062aed
--- /dev/null
+++ b/internal/tracing.go
@@ -0,0 +1,64 @@
+// Copyright 2023 The Matrix.org Foundation C.I.C.
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+package internal
+
+import (
+ "context"
+ "runtime/trace"
+
+ "github.com/opentracing/opentracing-go"
+)
+
+type Trace struct {
+ span opentracing.Span
+ region *trace.Region
+ task *trace.Task
+}
+
+func StartTask(inCtx context.Context, name string) (Trace, context.Context) {
+ ctx, task := trace.NewTask(inCtx, name)
+ span, ctx := opentracing.StartSpanFromContext(ctx, name)
+ return Trace{
+ span: span,
+ task: task,
+ }, ctx
+}
+
+func StartRegion(inCtx context.Context, name string) (Trace, context.Context) {
+ region := trace.StartRegion(inCtx, name)
+ span, ctx := opentracing.StartSpanFromContext(inCtx, name)
+ return Trace{
+ span: span,
+ region: region,
+ }, ctx
+}
+
+func (t Trace) EndRegion() {
+ t.span.Finish()
+ if t.region != nil {
+ t.region.End()
+ }
+}
+
+func (t Trace) EndTask() {
+ t.span.Finish()
+ if t.task != nil {
+ t.task.End()
+ }
+}
+
+func (t Trace) SetTag(key string, value any) {
+ t.span.SetTag(key, value)
+}
diff --git a/internal/tracing_test.go b/internal/tracing_test.go
new file mode 100644
index 00000000..582f50c3
--- /dev/null
+++ b/internal/tracing_test.go
@@ -0,0 +1,25 @@
+package internal
+
+import (
+ "context"
+ "testing"
+
+ "github.com/stretchr/testify/assert"
+)
+
+func TestTracing(t *testing.T) {
+ inCtx := context.Background()
+
+ task, ctx := StartTask(inCtx, "testing")
+ assert.NotNil(t, ctx)
+ assert.NotNil(t, task)
+ assert.NotEqual(t, inCtx, ctx)
+ task.SetTag("key", "value")
+
+ region, ctx2 := StartRegion(ctx, "testing")
+ assert.NotNil(t, ctx)
+ assert.NotNil(t, region)
+ assert.NotEqual(t, ctx, ctx2)
+ defer task.EndTask()
+ defer region.EndRegion()
+}
diff --git a/roomserver/internal/input/input_events.go b/roomserver/internal/input/input_events.go
index d709541b..7c7a902f 100644
--- a/roomserver/internal/input/input_events.go
+++ b/roomserver/internal/input/input_events.go
@@ -28,7 +28,6 @@ import (
"github.com/matrix-org/gomatrixserverlib"
"github.com/matrix-org/util"
- "github.com/opentracing/opentracing-go"
"github.com/prometheus/client_golang/prometheus"
"github.com/sirupsen/logrus"
@@ -85,10 +84,10 @@ func (r *Inputer) processRoomEvent(
default:
}
- span, ctx := opentracing.StartSpanFromContext(ctx, "processRoomEvent")
- span.SetTag("room_id", input.Event.RoomID())
- span.SetTag("event_id", input.Event.EventID())
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "processRoomEvent")
+ trace.SetTag("room_id", input.Event.RoomID())
+ trace.SetTag("event_id", input.Event.EventID())
+ defer trace.EndRegion()
// Measure how long it takes to process this event.
started := time.Now()
@@ -608,8 +607,8 @@ func (r *Inputer) fetchAuthEvents(
known map[string]*types.Event,
servers []gomatrixserverlib.ServerName,
) error {
- span, ctx := opentracing.StartSpanFromContext(ctx, "fetchAuthEvents")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "fetchAuthEvents")
+ defer trace.EndRegion()
unknown := map[string]struct{}{}
authEventIDs := event.AuthEventIDs()
@@ -753,8 +752,8 @@ func (r *Inputer) calculateAndSetState(
event *gomatrixserverlib.Event,
isRejected bool,
) error {
- span, ctx := opentracing.StartSpanFromContext(ctx, "calculateAndSetState")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "calculateAndSetState")
+ defer trace.EndRegion()
var succeeded bool
updater, err := r.DB.GetRoomUpdater(ctx, roomInfo)
diff --git a/roomserver/internal/input/input_latest_events.go b/roomserver/internal/input/input_latest_events.go
index a223820e..09db1843 100644
--- a/roomserver/internal/input/input_latest_events.go
+++ b/roomserver/internal/input/input_latest_events.go
@@ -23,9 +23,9 @@ import (
"github.com/getsentry/sentry-go"
"github.com/matrix-org/gomatrixserverlib"
"github.com/matrix-org/util"
- "github.com/opentracing/opentracing-go"
"github.com/sirupsen/logrus"
+ "github.com/matrix-org/dendrite/internal"
"github.com/matrix-org/dendrite/internal/sqlutil"
"github.com/matrix-org/dendrite/roomserver/api"
"github.com/matrix-org/dendrite/roomserver/state"
@@ -59,8 +59,8 @@ func (r *Inputer) updateLatestEvents(
rewritesState bool,
historyVisibility gomatrixserverlib.HistoryVisibility,
) (err error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "updateLatestEvents")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "updateLatestEvents")
+ defer trace.EndRegion()
var succeeded bool
updater, err := r.DB.GetRoomUpdater(ctx, roomInfo)
@@ -209,8 +209,8 @@ func (u *latestEventsUpdater) doUpdateLatestEvents() error {
}
func (u *latestEventsUpdater) latestState() error {
- span, ctx := opentracing.StartSpanFromContext(u.ctx, "processEventWithMissingState")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(u.ctx, "processEventWithMissingState")
+ defer trace.EndRegion()
var err error
roomState := state.NewStateResolution(u.updater, u.roomInfo)
@@ -329,8 +329,8 @@ func (u *latestEventsUpdater) calculateLatest(
newEvent *gomatrixserverlib.Event,
newStateAndRef types.StateAtEventAndReference,
) (bool, error) {
- span, _ := opentracing.StartSpanFromContext(u.ctx, "calculateLatest")
- defer span.Finish()
+ trace, _ := internal.StartRegion(u.ctx, "calculateLatest")
+ defer trace.EndRegion()
// First of all, get a list of all of the events in our current
// set of forward extremities.
diff --git a/roomserver/internal/input/input_membership.go b/roomserver/internal/input/input_membership.go
index e1dfa6cf..4028f0b5 100644
--- a/roomserver/internal/input/input_membership.go
+++ b/roomserver/internal/input/input_membership.go
@@ -18,13 +18,14 @@ import (
"context"
"fmt"
+ "github.com/matrix-org/gomatrixserverlib"
+
+ "github.com/matrix-org/dendrite/internal"
"github.com/matrix-org/dendrite/roomserver/api"
"github.com/matrix-org/dendrite/roomserver/internal/helpers"
"github.com/matrix-org/dendrite/roomserver/storage/shared"
"github.com/matrix-org/dendrite/roomserver/storage/tables"
"github.com/matrix-org/dendrite/roomserver/types"
- "github.com/matrix-org/gomatrixserverlib"
- "github.com/opentracing/opentracing-go"
)
// updateMembership updates the current membership and the invites for each
@@ -36,8 +37,8 @@ func (r *Inputer) updateMemberships(
updater *shared.RoomUpdater,
removed, added []types.StateEntry,
) ([]api.OutputEvent, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "updateMemberships")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "updateMemberships")
+ defer trace.EndRegion()
changes := membershipChanges(removed, added)
var eventNIDs []types.EventNID
diff --git a/roomserver/internal/input/input_missing.go b/roomserver/internal/input/input_missing.go
index 9627f15a..daef957f 100644
--- a/roomserver/internal/input/input_missing.go
+++ b/roomserver/internal/input/input_missing.go
@@ -7,16 +7,16 @@ import (
"sync"
"time"
+ "github.com/matrix-org/gomatrixserverlib"
+ "github.com/matrix-org/util"
+ "github.com/sirupsen/logrus"
+
fedapi "github.com/matrix-org/dendrite/federationapi/api"
"github.com/matrix-org/dendrite/internal"
"github.com/matrix-org/dendrite/roomserver/api"
"github.com/matrix-org/dendrite/roomserver/state"
"github.com/matrix-org/dendrite/roomserver/storage"
"github.com/matrix-org/dendrite/roomserver/types"
- "github.com/matrix-org/gomatrixserverlib"
- "github.com/matrix-org/util"
- "github.com/opentracing/opentracing-go"
- "github.com/sirupsen/logrus"
)
type parsedRespState struct {
@@ -62,8 +62,8 @@ type missingStateReq struct {
func (t *missingStateReq) processEventWithMissingState(
ctx context.Context, e *gomatrixserverlib.Event, roomVersion gomatrixserverlib.RoomVersion,
) (*parsedRespState, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "processEventWithMissingState")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "processEventWithMissingState")
+ defer trace.EndRegion()
// We are missing the previous events for this events.
// This means that there is a gap in our view of the history of the
@@ -241,8 +241,8 @@ func (t *missingStateReq) processEventWithMissingState(
}
func (t *missingStateReq) lookupResolvedStateBeforeEvent(ctx context.Context, e *gomatrixserverlib.Event, roomVersion gomatrixserverlib.RoomVersion) (*parsedRespState, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "lookupResolvedStateBeforeEvent")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "lookupResolvedStateBeforeEvent")
+ defer trace.EndRegion()
type respState struct {
// A snapshot is considered trustworthy if it came from our own roomserver.
@@ -319,8 +319,8 @@ func (t *missingStateReq) lookupResolvedStateBeforeEvent(ctx context.Context, e
// lookupStateAfterEvent returns the room state after `eventID`, which is the state before eventID with the state of `eventID` (if it's a state event)
// added into the mix.
func (t *missingStateReq) lookupStateAfterEvent(ctx context.Context, roomVersion gomatrixserverlib.RoomVersion, roomID, eventID string) (*parsedRespState, bool, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "lookupStateAfterEvent")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "lookupStateAfterEvent")
+ defer trace.EndRegion()
// try doing all this locally before we resort to querying federation
respState := t.lookupStateAfterEventLocally(ctx, eventID)
@@ -376,8 +376,8 @@ func (t *missingStateReq) cacheAndReturn(ev *gomatrixserverlib.Event) *gomatrixs
}
func (t *missingStateReq) lookupStateAfterEventLocally(ctx context.Context, eventID string) *parsedRespState {
- span, ctx := opentracing.StartSpanFromContext(ctx, "lookupStateAfterEventLocally")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "lookupStateAfterEventLocally")
+ defer trace.EndRegion()
var res parsedRespState
roomState := state.NewStateResolution(t.db, t.roomInfo)
@@ -449,16 +449,16 @@ func (t *missingStateReq) lookupStateAfterEventLocally(ctx context.Context, even
// the server supports.
func (t *missingStateReq) lookupStateBeforeEvent(ctx context.Context, roomVersion gomatrixserverlib.RoomVersion, roomID, eventID string) (
*parsedRespState, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "lookupStateBeforeEvent")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "lookupStateBeforeEvent")
+ defer trace.EndRegion()
// Attempt to fetch the missing state using /state_ids and /events
return t.lookupMissingStateViaStateIDs(ctx, roomID, eventID, roomVersion)
}
func (t *missingStateReq) resolveStatesAndCheck(ctx context.Context, roomVersion gomatrixserverlib.RoomVersion, states []*parsedRespState, backwardsExtremity *gomatrixserverlib.Event) (*parsedRespState, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "resolveStatesAndCheck")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "resolveStatesAndCheck")
+ defer trace.EndRegion()
var authEventList []*gomatrixserverlib.Event
var stateEventList []*gomatrixserverlib.Event
@@ -503,8 +503,8 @@ retryAllowedState:
// get missing events for `e`. If `isGapFilled`=true then `newEvents` contains all the events to inject,
// without `e`. If `isGapFilled=false` then `newEvents` contains the response to /get_missing_events
func (t *missingStateReq) getMissingEvents(ctx context.Context, e *gomatrixserverlib.Event, roomVersion gomatrixserverlib.RoomVersion) (newEvents []*gomatrixserverlib.Event, isGapFilled, prevStateKnown bool, err error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "getMissingEvents")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "getMissingEvents")
+ defer trace.EndRegion()
logger := t.log.WithField("event_id", e.EventID()).WithField("room_id", e.RoomID())
latest, _, _, err := t.db.LatestEventIDs(ctx, t.roomInfo.RoomNID)
@@ -633,8 +633,8 @@ func (t *missingStateReq) isPrevStateKnown(ctx context.Context, e *gomatrixserve
func (t *missingStateReq) lookupMissingStateViaState(
ctx context.Context, roomID, eventID string, roomVersion gomatrixserverlib.RoomVersion,
) (respState *parsedRespState, err error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "lookupMissingStateViaState")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "lookupMissingStateViaState")
+ defer trace.EndRegion()
state, err := t.federation.LookupState(ctx, t.virtualHost, t.origin, roomID, eventID, roomVersion)
if err != nil {
@@ -665,8 +665,8 @@ func (t *missingStateReq) lookupMissingStateViaState(
func (t *missingStateReq) lookupMissingStateViaStateIDs(ctx context.Context, roomID, eventID string, roomVersion gomatrixserverlib.RoomVersion) (
*parsedRespState, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "lookupMissingStateViaStateIDs")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "lookupMissingStateViaStateIDs")
+ defer trace.EndRegion()
t.log.Infof("lookupMissingStateViaStateIDs %s", eventID)
// fetch the state event IDs at the time of the event
@@ -839,8 +839,8 @@ func (t *missingStateReq) createRespStateFromStateIDs(
}
func (t *missingStateReq) lookupEvent(ctx context.Context, roomVersion gomatrixserverlib.RoomVersion, _, missingEventID string, localFirst bool) (*gomatrixserverlib.Event, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "lookupEvent")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "lookupEvent")
+ defer trace.EndRegion()
if localFirst {
// fetch from the roomserver
diff --git a/roomserver/state/state.go b/roomserver/state/state.go
index 47e1488d..c3842784 100644
--- a/roomserver/state/state.go
+++ b/roomserver/state/state.go
@@ -25,9 +25,9 @@ import (
"github.com/matrix-org/gomatrixserverlib"
"github.com/matrix-org/util"
- "github.com/opentracing/opentracing-go"
"github.com/prometheus/client_golang/prometheus"
+ "github.com/matrix-org/dendrite/internal"
"github.com/matrix-org/dendrite/roomserver/types"
)
@@ -106,8 +106,8 @@ func (p *StateResolution) Resolve(ctx context.Context, eventID string) (*gomatri
func (v *StateResolution) LoadStateAtSnapshot(
ctx context.Context, stateNID types.StateSnapshotNID,
) ([]types.StateEntry, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.LoadStateAtSnapshot")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.LoadStateAtSnapshot")
+ defer trace.EndRegion()
stateBlockNIDLists, err := v.db.StateBlockNIDs(ctx, []types.StateSnapshotNID{stateNID})
if err != nil {
@@ -147,8 +147,8 @@ func (v *StateResolution) LoadStateAtSnapshot(
func (v *StateResolution) LoadStateAtEvent(
ctx context.Context, eventID string,
) ([]types.StateEntry, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.LoadStateAtEvent")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.LoadStateAtEvent")
+ defer trace.EndRegion()
snapshotNID, err := v.db.SnapshotNIDFromEventID(ctx, eventID)
if err != nil {
@@ -169,8 +169,8 @@ func (v *StateResolution) LoadStateAtEvent(
func (v *StateResolution) LoadMembershipAtEvent(
ctx context.Context, eventIDs []string, stateKeyNID types.EventStateKeyNID,
) (map[string][]types.StateEntry, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.LoadMembershipAtEvent")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.LoadMembershipAtEvent")
+ defer trace.EndRegion()
// Get a mapping from snapshotNID -> eventIDs
snapshotNIDMap, err := v.db.BulkSelectSnapshotsFromEventIDs(ctx, eventIDs)
@@ -238,8 +238,8 @@ func (v *StateResolution) LoadMembershipAtEvent(
func (v *StateResolution) LoadStateAtEventForHistoryVisibility(
ctx context.Context, eventID string,
) ([]types.StateEntry, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.LoadStateAtEvent")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.LoadStateAtEventForHistoryVisibility")
+ defer trace.EndRegion()
snapshotNID, err := v.db.SnapshotNIDFromEventID(ctx, eventID)
if err != nil {
@@ -263,8 +263,8 @@ func (v *StateResolution) LoadStateAtEventForHistoryVisibility(
func (v *StateResolution) LoadCombinedStateAfterEvents(
ctx context.Context, prevStates []types.StateAtEvent,
) ([]types.StateEntry, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.LoadCombinedStateAfterEvents")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.LoadCombinedStateAfterEvents")
+ defer trace.EndRegion()
stateNIDs := make([]types.StateSnapshotNID, len(prevStates))
for i, state := range prevStates {
@@ -338,8 +338,8 @@ func (v *StateResolution) LoadCombinedStateAfterEvents(
func (v *StateResolution) DifferenceBetweeenStateSnapshots(
ctx context.Context, oldStateNID, newStateNID types.StateSnapshotNID,
) (removed, added []types.StateEntry, err error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.DifferenceBetweeenStateSnapshots")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.DifferenceBetweeenStateSnapshots")
+ defer trace.EndRegion()
if oldStateNID == newStateNID {
// If the snapshot NIDs are the same then nothing has changed
@@ -402,8 +402,8 @@ func (v *StateResolution) LoadStateAtSnapshotForStringTuples(
stateNID types.StateSnapshotNID,
stateKeyTuples []gomatrixserverlib.StateKeyTuple,
) ([]types.StateEntry, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.LoadStateAtSnapshotForStringTuples")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.LoadStateAtSnapshotForStringTuples")
+ defer trace.EndRegion()
numericTuples, err := v.stringTuplesToNumericTuples(ctx, stateKeyTuples)
if err != nil {
@@ -419,8 +419,8 @@ func (v *StateResolution) stringTuplesToNumericTuples(
ctx context.Context,
stringTuples []gomatrixserverlib.StateKeyTuple,
) ([]types.StateKeyTuple, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.stringTuplesToNumericTuples")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.stringTuplesToNumericTuples")
+ defer trace.EndRegion()
eventTypes := make([]string, len(stringTuples))
stateKeys := make([]string, len(stringTuples))
@@ -464,8 +464,8 @@ func (v *StateResolution) loadStateAtSnapshotForNumericTuples(
stateNID types.StateSnapshotNID,
stateKeyTuples []types.StateKeyTuple,
) ([]types.StateEntry, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.loadStateAtSnapshotForNumericTuples")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.loadStateAtSnapshotForNumericTuples")
+ defer trace.EndRegion()
stateBlockNIDLists, err := v.db.StateBlockNIDs(ctx, []types.StateSnapshotNID{stateNID})
if err != nil {
@@ -515,8 +515,8 @@ func (v *StateResolution) LoadStateAfterEventsForStringTuples(
prevStates []types.StateAtEvent,
stateKeyTuples []gomatrixserverlib.StateKeyTuple,
) ([]types.StateEntry, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.LoadStateAfterEventsForStringTuples")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.LoadStateAfterEventsForStringTuples")
+ defer trace.EndRegion()
numericTuples, err := v.stringTuplesToNumericTuples(ctx, stateKeyTuples)
if err != nil {
@@ -530,8 +530,8 @@ func (v *StateResolution) loadStateAfterEventsForNumericTuples(
prevStates []types.StateAtEvent,
stateKeyTuples []types.StateKeyTuple,
) ([]types.StateEntry, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.loadStateAfterEventsForNumericTuples")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.loadStateAfterEventsForNumericTuples")
+ defer trace.EndRegion()
if len(prevStates) == 1 {
// Fast path for a single event.
@@ -705,8 +705,8 @@ func (v *StateResolution) CalculateAndStoreStateBeforeEvent(
event *gomatrixserverlib.Event,
isRejected bool,
) (types.StateSnapshotNID, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.CalculateAndStoreStateBeforeEvent")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.CalculateAndStoreStateBeforeEvent")
+ defer trace.EndRegion()
// Load the state at the prev events.
prevStates, err := v.db.StateAtEventIDs(ctx, event.PrevEventIDs())
@@ -724,8 +724,8 @@ func (v *StateResolution) CalculateAndStoreStateAfterEvents(
ctx context.Context,
prevStates []types.StateAtEvent,
) (types.StateSnapshotNID, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.CalculateAndStoreStateAfterEvents")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.CalculateAndStoreStateAfterEvents")
+ defer trace.EndRegion()
metrics := calculateStateMetrics{startTime: time.Now(), prevEventLength: len(prevStates)}
@@ -799,8 +799,8 @@ func (v *StateResolution) calculateAndStoreStateAfterManyEvents(
prevStates []types.StateAtEvent,
metrics calculateStateMetrics,
) (types.StateSnapshotNID, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.calculateAndStoreStateAfterManyEvents")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.calculateAndStoreStateAfterManyEvents")
+ defer trace.EndRegion()
state, algorithm, conflictLength, err :=
v.calculateStateAfterManyEvents(ctx, v.roomInfo.RoomVersion, prevStates)
@@ -820,8 +820,8 @@ func (v *StateResolution) calculateStateAfterManyEvents(
ctx context.Context, roomVersion gomatrixserverlib.RoomVersion,
prevStates []types.StateAtEvent,
) (state []types.StateEntry, algorithm string, conflictLength int, err error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.calculateStateAfterManyEvents")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.calculateStateAfterManyEvents")
+ defer trace.EndRegion()
var combined []types.StateEntry
// Conflict resolution.
@@ -875,8 +875,8 @@ func (v *StateResolution) resolveConflicts(
ctx context.Context, version gomatrixserverlib.RoomVersion,
notConflicted, conflicted []types.StateEntry,
) ([]types.StateEntry, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.resolveConflicts")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.resolveConflicts")
+ defer trace.EndRegion()
stateResAlgo, err := version.StateResAlgorithm()
if err != nil {
@@ -902,8 +902,8 @@ func (v *StateResolution) resolveConflictsV1(
ctx context.Context,
notConflicted, conflicted []types.StateEntry,
) ([]types.StateEntry, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.resolveConflictsV1")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.resolveConflictsV1")
+ defer trace.EndRegion()
// Load the conflicted events
conflictedEvents, eventIDMap, err := v.loadStateEvents(ctx, conflicted)
@@ -967,8 +967,8 @@ func (v *StateResolution) resolveConflictsV2(
ctx context.Context,
notConflicted, conflicted []types.StateEntry,
) ([]types.StateEntry, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.resolveConflictsV2")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.resolveConflictsV2")
+ defer trace.EndRegion()
estimate := len(conflicted) + len(notConflicted)
eventIDMap := make(map[string]types.StateEntry, estimate)
@@ -1000,8 +1000,8 @@ func (v *StateResolution) resolveConflictsV2(
// For each conflicted event, let's try and get the needed auth events.
if err = func() error {
- span, sctx := opentracing.StartSpanFromContext(ctx, "StateResolution.loadAuthEvents")
- defer span.Finish()
+ loadAuthEventsTrace, sctx := internal.StartRegion(ctx, "StateResolution.loadAuthEvents")
+ defer loadAuthEventsTrace.EndRegion()
loader := authEventLoader{
v: v,
@@ -1045,8 +1045,8 @@ func (v *StateResolution) resolveConflictsV2(
// Resolve the conflicts.
resolvedEvents := func() []*gomatrixserverlib.Event {
- span, _ := opentracing.StartSpanFromContext(ctx, "gomatrixserverlib.ResolveStateConflictsV2")
- defer span.Finish()
+ resolvedTrace, _ := internal.StartRegion(ctx, "StateResolution.ResolveStateConflictsV2")
+ defer resolvedTrace.EndRegion()
return gomatrixserverlib.ResolveStateConflictsV2(
conflictedEvents,
@@ -1118,8 +1118,8 @@ func (v *StateResolution) stateKeyTuplesNeeded(stateKeyNIDMap map[string]types.E
func (v *StateResolution) loadStateEvents(
ctx context.Context, entries []types.StateEntry,
) ([]*gomatrixserverlib.Event, map[string]types.StateEntry, error) {
- span, ctx := opentracing.StartSpanFromContext(ctx, "StateResolution.loadStateEvents")
- defer span.Finish()
+ trace, ctx := internal.StartRegion(ctx, "StateResolution.loadStateEvents")
+ defer trace.EndRegion()
result := make([]*gomatrixserverlib.Event, 0, len(entries))
eventEntries := make([]types.StateEntry, 0, len(entries))