在#105中,davidB 问道:
我想拥有对 Span id (SpanContext id) 的读取权限,以便能够在日志中使用它并报告错误(给最终用户,...)。[skip] 我需要在错误消息中公开“trace id”,然后开发人员可以使用该跟踪来调试支持、QA、最终用户报告的错误。
在#105中,davidB 问道:
我想拥有对 Span id (SpanContext id) 的读取权限,以便能够在日志中使用它并报告错误(给最终用户,...)。[skip] 我需要在错误消息中公开“trace id”,然后开发人员可以使用该跟踪来调试支持、QA、最终用户报告的错误。
目前OpenTracing API不公开跟踪 ID。本期正在讨论它:https ://github.com/opentracing/specification/issues/24
您现在可以做的一件事是致电tracer.inject(null, Builtin.HTTP_HEADERS, map
. 它将所有带有行李(SpanContext)的ID放入地图中。然后,您可以通过其名称获取 ID。然而,这个解决方案不是 vedor 中立的。
其他解决方案是转换SpanContext
为特定实现并通过getter获取ID(如果有的话)
在春天我用这个:
Span span = tracer.activeSpan();
response.addHeader("trace-id", span.context().toTraceId());
io.opentracing.Tracer tracer
我在 Spring 注入的地方
Ben 提供了一种提供此 ID 的新方法。参考:https ://github.com/opentracing/specification/issues/24#issuecomment-286261320