sl4j MDC如何应用

本文介绍了如何在项目中利用slf4j的MDC(Mapped Diagnostic Context)功能,以增强日志信息,特别是在线程ID等关键信息的记录,便于在多线程或多节点环境中定位问题。通过研究log4j配置,了解到%X是用于获取MDC记录的参数,而MDC的数据可以通过org.apache.logging.log4j.ThreadContext进行put操作。对于log4j2,slf4j的MDC.put方法不可用。文章还探讨了slf4j MDC与AOP切面结合使用的方法,以实现更高效的问题排查。
摘要由CSDN通过智能技术生成

因为之前项目中log4j配置文件使用如下,因为在使用中我发现日志中会有类似于线程id一样的东西   这在多线程 或者多节点查询日志前因后果  用于定位问题特别方便  所以找了好长时间 才捋清楚如何实现该功能。

<PatternLayout pattern="%C|%M|%p|%X{teid}|%X{rtid}|%X{tnid}|%t %d [%7r] - %m \n"/>

 根据上面上面我对应出来 那几个值分别是  %X{teid}|%X{rtid}|%X{tnid}   然后开始百度%X

上面的%是什么含义,还有哪些呢?其实最主要的参数还是%d, %p, %l, %m, %n, %X。下面的图是摘取网上的。

%X用来获取MDC记录,这些记录从哪来的?我们可以使用org.apache.logging.log4j.ThreadContext将需要记录的值put进去。(我发现slf的MDC.java的put方法对log4j2不可用,因为底层依赖的是log4j1)

因为我这个是log4j4 可以实现MDC

这个就可以和切面结合一起

加一个日志切面

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值