Jaeger客户端初始化报nil pointer dereference因未设置有效tracer,须在main开头调用opentracing.SetGlobalTracer;HTTP透传需用opentracing.HTTPHeadersCarrier;Tag/Log值禁用nil指针;UDP连Agent失败应检查端口、Docker网络及改用TCP reporter。Jaeger客户端初始化为什么总报错 nil pointer dereference常见原因是没传入有效的 tracer,或在调用 opentracing.StartSpan 前没完成初始化。Jaeger 的 Go SDK 不会自动 fallback,opentracing.GlobalTracer() 默认返回空实现,直接用它开 Span 就 panic。必须显式创建并设置全局 tracer:opentracing.SetGlobalTracer(tracer),且这行要在任何 Span 创建之前执行推荐在 main() 开头、配置加载后立即初始化,不要懒加载或放 goroutine 里如果用 jaeger.NewTracer,注意第 2 个参数(jaeger.Configuration.Sampler)不能为 nil;采样器至少得是 jaeger.NewConstSampler(true)本地调试时,jaeger.NewCollector() 若连不上 Agent,默认会静默失败——加 jaeger.WithLogger 才能看到连接错误怎么让 HTTP 请求自动带上 TraceID 并透传到下游服务Go 标准库不自动注入/提取 trace 上下文,必须手动做。核心是用 opentracing.HTTPHeadersCarrier 在请求头中写入 uber-trace-id。发起请求前:从当前 Span 获取上下文,用 tracer.Inject(span.Context(), opentracing.HTTPHeaders, carrier)接收请求时:用 tracer.Extract(opentracing.HTTPHeaders, carrier) 恢复 SpanContext,再 StartSpanFromContext别直接读写 r.Header.Get("uber-trace-id")——要用 opentracing.HTTPHeadersCarrier 包装 map,否则大小写、空格处理不一致如果下游是 Python/Java 服务,确保 header key 是小写 uber-trace-id(Jaeger Go SDK 默认用这个),不是 Uber-Trace-Id为什么 Span 看不到日志(Log)或 Tag,或者 Tag 值是
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/266795.html