sl4j MDC如何应用
因为之前项目中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
这个就可以和切面结合一起
加一个日志切面