代码中获取sleuth的traceId

需求场景

获取轨迹id做链路跟踪

老老实实看源码找到的方法

        MDCAdapter mdc = MDC.getMDCAdapter();
        Map<String, String> map=((LogbackMDCAdapter)mdc).getPropertyMap();
        String traceId=map.get("traceId");
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Java获取Zipkin的traceId,你需要使用Zipkin的客户端库。推荐使用Spring Cloud Sleuth作为Zipkin的客户端库。以下是使用Spring Cloud Sleuth获取Zipkin traceId的步骤: 1. 首先,确保你的项目已经添加了Spring Cloud Sleuth的依赖。在你的Maven或Gradle配置文件添加相应的依赖。 2. 在你的Spring Boot主类上添加`@EnableZipkinTracing`注解,它会启用Spring Cloud Sleuth的Zipkin支持。 3. 在你的应用程序,你可以使用`Tracer`类来获取当前请求的traceId。可以通过注入`Tracer`类或通过`RequestContextHolder.getRequestAttributes()`方法来获取`Tracer`实例。 4. 使用`Tracer`类的`currentSpan()`方法可以获取当前的跟踪span。然后,通过调用`getTraceId()`方法即可获取traceId。 以下是一个示例代码: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.cloud.sleuth.Tracer; import org.springframework.stereotype.Component; import org.springframework.web.context.request.RequestContextHolder; import org.springframework.web.context.request.ServletRequestAttributes; @Component public class ZipkinTraceIdExample { @Autowired Tracer tracer; public void getTraceId() { // 通过Tracer类获取当前请求的traceId String traceId = tracer.currentSpan().context().traceIdString(); System.out.println("TraceId: " + traceId); } public void getTraceIdFromHttpServletRequest() { // 通过HttpServletRequest获取当前请求的traceId ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); String traceId = attributes.getRequest().getHeader("X-B3-TraceId"); System.out.println("TraceId: " + traceId); } } ``` 通过以上步骤,你就可以在Java应用程序获取到Zipkin的traceId了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值