如何解决将 dd-trace-go 用于工作人员跨度 ID
我正在尝试为我的工作人员设置 dd-trace-go,它侦听活动的 mq 队列并处理消息。但是,如果我将上下文传递给另一个函数,我将无法获得跨度 ID。这是一个演示:
package main
import (
"context"
"github.com/davecgh/go-spew/spew"
"gopkg.in/DataDog/dd-trace-go.v1/ddtrace/tracer"
)
func main() {
tracer.Start(
tracer.WithServiceName("my-worker"),tracer.WithGlobalTag("env","dev"),)
defer tracer.Stop()
ctx := context.Background()
// for loop to listen a message here
// for every loop,init contextWithCancel
ctxWithCancel,cancelFunction := context.WithCancel(ctx)
span,_ := tracer.StartSpanFromContext(ctxWithCancel,"Listen",tracer.ServiceName("my-worker"))
spew.Dump(ctxWithCancel)
spew.Dump(span.Context().TraceID())
test(ctxWithCancel)
cancelFunction()
}
// callback to process the message
func test(c context.Context) {
span,_ := tracer.SpanFromContext(c)
spew.Dump("inside test function")
spew.Dump(span.Context().TraceID())
}
输出为:
(*context.cancelCtx)(0xc00006ce80)(context.Background.WithCancel)
(uint64) 6512722789050192664
(string) (len=20) "inside test function"
(uint64) 0
为什么测试函数中的跟踪 ID 是 0 而不是 6512722789050192664 ?谢谢
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。