mirror of
https://gitee.com/milvus-io/milvus.git
synced 2024-12-02 11:59:00 +08:00
28 lines
807 B
Go
28 lines
807 B
Go
|
package tracer
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
|
||
|
"go.opentelemetry.io/otel/trace"
|
||
|
"go.uber.org/zap"
|
||
|
|
||
|
"github.com/milvus-io/milvus/pkg/log"
|
||
|
)
|
||
|
|
||
|
// SetupSpan add span into ctx values.
|
||
|
// Also setup logger in context with tracerID field.
|
||
|
func SetupSpan(ctx context.Context, span trace.Span) context.Context {
|
||
|
ctx = trace.ContextWithSpan(ctx, span)
|
||
|
ctx = log.WithFields(ctx, zap.Stringer("traceID", span.SpanContext().TraceID()))
|
||
|
return ctx
|
||
|
}
|
||
|
|
||
|
// Propagate passes span context into a new ctx with different lifetime.
|
||
|
// Also setup logger in new context with traceID field.
|
||
|
func Propagate(ctx, newRoot context.Context) context.Context {
|
||
|
spanCtx := trace.SpanContextFromContext(ctx)
|
||
|
|
||
|
newCtx := trace.ContextWithSpanContext(newRoot, spanCtx)
|
||
|
return log.WithFields(newCtx, zap.Stringer("traceID", spanCtx.TraceID()))
|
||
|
}
|