要建立 Span 之间的父子关系,必须在上下文传播不可行的情况下使用标头。在这种情况下,跟踪 ID 和跨度 ID 包含在消息代理的标头中,这允许订阅者使用父跟踪 ID 创建新的跨度。
以下步骤可以使用跟踪 ID 在订阅者端构建上下文或跨度:
func constructNewSpanContext(traceID string) (spanContext trace.SpanContext, err error) {
traceID, err := trace.TraceIDFromHex(traceID)
if err != nil {
return trace.SpanContext{}, err
}
return trace.NewSpanContext(trace.SpanContextConfig{
TraceID: traceID,
}), nil
}
spanContext, err := constructNewSpanContext(request.TraceID)
if err != nil {
log.Fatal(err)
}
requestContext := context.Background()
requestContext = trace.ContextWithSpanContext(requestContext, spanContext)
requestInLoopSpan, _ := otel.Tracer("requestInLoop").Start(requestContext, "requestInLoopSpan")
通过以下步骤,您可以使用从消息头中提取的trace ID在订阅者端成功构造一个新的span,从而确保span之间的层次关系跨度。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3