milvus/pkg/mq/msgstream/trace.go

89 lines
2.8 KiB
Go

// Licensed to the LF AI & Data foundation under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you 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 msgstream
import (
"context"
"go.opentelemetry.io/otel"
"go.opentelemetry.io/otel/attribute"
"go.opentelemetry.io/otel/propagation"
"go.opentelemetry.io/otel/trace"
"github.com/milvus-io/milvus-proto/go-api/v2/commonpb"
)
// ExtractCtx extracts trace span from msg.properties.
// And it will attach some default tags to the span.
func ExtractCtx(msg TsMsg, properties map[string]string) (context.Context, trace.Span) {
ctx := msg.TraceCtx()
if ctx == nil {
ctx = context.Background()
}
if !allowTrace(msg) {
return ctx, trace.SpanFromContext(ctx)
}
ctx = otel.GetTextMapPropagator().Extract(ctx, propagation.MapCarrier(properties))
name := "ReceieveMsg"
return otel.Tracer(name).Start(ctx, name, trace.WithAttributes(
attribute.Int64("ID", msg.ID()),
attribute.String("Type", msg.Type().String()),
// attribute.Int64Value("HashKeys", msg.HashKeys()),
attribute.String("Position", msg.Position().String()),
))
}
// InjectCtx is a method inject span to pulsr message.
func InjectCtx(sc context.Context, properties map[string]string) {
if sc == nil {
return
}
otel.GetTextMapPropagator().Inject(sc, propagation.MapCarrier(properties))
}
// MsgSpanFromCtx extracts the span from context.
// And it will attach some default tags to the span.
func MsgSpanFromCtx(ctx context.Context, msg TsMsg) (context.Context, trace.Span) {
if ctx == nil {
return ctx, trace.SpanFromContext(ctx)
}
if !allowTrace(msg) {
return ctx, trace.SpanFromContext(ctx)
}
operationName := "SendMsg"
opts := trace.WithAttributes(
attribute.Int64("ID", msg.ID()),
attribute.String("Type", msg.Type().String()),
// attribute.Int64Value("HashKeys", msg.HashKeys()),
attribute.String("Position", msg.Position().String()),
)
return otel.Tracer(operationName).Start(ctx, operationName, opts)
}
func allowTrace(in interface{}) bool {
if in == nil {
return false
}
switch res := in.(type) {
case TsMsg:
return !(res.Type() == commonpb.MsgType_TimeTick ||
res.Type() == commonpb.MsgType_LoadIndex)
default:
return false
}
}