mirror of https://github.com/milvus-io/milvus.git
89 lines
2.8 KiB
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
|
|
}
|
|
}
|