首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在Spring Sleuth和brave中使用TraceContext设置traceId?

如何在Spring Sleuth和brave中使用TraceContext设置traceId?
EN

Stack Overflow用户
提问于 2018-12-06 22:29:15
回答 1查看 3.7K关注 0票数 1

我需要用现有的Id (我们已经从主源应用程序创建了某种traceId -id)将关联设置为勇敢的跟踪程序。

我不想使用Spring Sleuth/brave创建的微服务,因为我想让它在我的不同微服务中保持一致。我能够创建痕迹和跨度,并能够发送到Zipkin的所有细节。我的示例代码片段:

代码语言:javascript
复制
import brave.Span;
import brave.Span.Kind;
import brave.Tracer;
import brave.propagation.TraceContext;  

span = this.tracer.nextSpan().name("myservice");
span.kind(Kind.SERVER);
span.tag("path", servletPath).start();

我使用的是: Spring Cloud 'Greenwich.BUILD-SNAPSHOT‘和勇敢。整个目的是在zipkin ui中使用correlationId而不是traceId进行搜索。

EN

回答 1

Stack Overflow用户

发布于 2018-12-07 00:27:45

您将需要自己的PropagationFactory实现。下面是默认设置:https://github.com/openzipkin/brave/blob/master/brave/src/main/java/brave/propagation/B3Propagation.java

你可以创建一个bean,侦探应该使用它而不是这个。

更具体地说,您将需要一个具有自定义TraceContext.Extractor<C>实现的实现。然后,这可以从您的头中提取跟踪ID,并添加并返回适当的TraceContext。然后,它可以使用正常的头部传递它。如果您希望在发送下行数据时使用相同的相关头,那么您还必须实现TraceContext.Injector<C>

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53653606

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档