Sleuth+logback 设置traceid 及自定义信息

背景:分布式系统中,如何快速定位某个用户的请求日志?

使用Sleuth生成的traceid可以跟踪某个请求,但是很多时候我们需要知道traceid 与某个用户的映射关系,方便定位某个用户的日志

方案:

@Component
@Order(TraceWebServletAutoConfiguration.TRACING_FILTER_ORDER + 1)
public class CustomHttpSpanExtractor extends GenericFilterBean {
    private final Tracer tracer;

    CustomHttpSpanExtractor(Tracer tracer) {
        this.tracer = tracer;
    }

    @Override
    public void doFilter(ServletRequest request, ServletResponse response,
                         FilterChain chain) throws IOException, ServletException {
        Span currentSpan = this.tracer.currentSpan();
        if (currentSpan == null) {
            chain.doFilter(request, response);
            return;
        }

        HttpServletRequest httpRequest = (HttpServletRequest) request;

        try {
          //  mdc(httpRequest,currentSpan.context().traceIdString());
            MDC.put(MdcConstant.USER_ID,"userid-12345");

        } catch (Exception e) {
            e.printStackTrace();
        }

        try {
            chain.doFilter(request, response);

        } finally {
            MDC.clear();//must be,threadLocal
        }

    }}

logback 配置

<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS}[${applicationName},%X{X-B3-TraceId:-},%X{userId:-}] [%thread] %-5level %logger{50} - %msg%n</pattern>

要在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了。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值