AOP+MDC实现traceId日志追踪

本文深入探讨了统一日志追踪技术的实现方法,通过在系统中引入TraceIdHandler类,利用AOP技术实现了对业务交易的日志追踪。具体而言,当业务方法被调用时,会自动生成一个唯一标识符(traceId),并将其记录在MDC中,以便后续日志收集和分析。此外,还介绍了如何配置Logback来显示这个traceId,确保每个日志条目都能包含这个关键信息。
/**
 * 统一日志追踪处理器
 *
 * @author dengy
 * @since jdk1.8
 */

@Slf4j
@Component
@Aspect
public class TraceIdHandler {

    private static final String TRACE_ID = "traceId";

    @Before(value = "execution(* com.xxx.exbiz.trans..*.*(..))")
    public void aroundHandle() {
        if (StringUtils.isBlank(MDC.get(TRACE_ID))) {
            String traceId = DateUtil.getSysTime() + "-" + ((int) ((Math.random() * 9 + 1) * 100000));
            MDC.put(TRACE_ID, traceId);
        }
    }
}
关键是--> [%X{traceId}]

<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
		<encoder class="com.llpay.framework.autoconfigure.logging.logback.SecurePatternLayoutEncoder">
	        <pattern>%d %-5p [%X{traceId}] %t [%c] - %m%n</pattern>
	        <charset>UTF-8</charset>
		</encoder>
	</appender>

 

转载于:https://my.oschina.net/dyyweb/blog/2980044

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值