什么是 MDC ? 为什么需要它实现日志跟踪?

MDC(Mapped Diagnostic Context)是 SLF4J 和 log4j 等日志框架提供的一种方案,它允许开发者将一些特定的数据(如用户ID、请求ID等)存储到当前线程的上下文中,使得这些数据可以在日志消息中使用。这对于跟踪多线程或高并发应用中的单个请求非常有用。

在高并发环境中,由于多个请求可能同时处理,日志消息可能会交错在一起。使用MDC,我们可以为每个请求分配一个唯一的标识,并将该标识添加到每条日志消息中,从而方便地区分和跟踪每个请求的日志。

代码如下
编辑日志切面类,在方法中处理请求开始的时候, 将请求的跟踪标识放入MDC 中:

// traceId 表示跟踪 ID, 值这里直接用的 UUID
MDC.put("traceId", UUID.randomUUID().toString());

配置日志框架

在 logback-weblog.xml 配置文件中,可以使用 %X 来引用MDC中的值。例如,要引用上述的 traceId,你可以这样配置:

[TraceId: %X{traceId}] %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n

清除 MDC 值

在请求结束时,为了避免污染其他请求,还需要清除 MDC 中的值:(在finally里执行)

MDC.clear();

有了它,就可以在查询日志的时候通过 traceId 来过滤出同一个请求的所有日志了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

-KaiS-

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值