问题描述
如果库使用 slf4j 并将数据放入 org.slf4j.MDC,我的使用 log4j2 进行日志记录的应用程序(使用此库)可以访问库设置的 MDC 变量吗?
解决方法
MDC 是一个线程安全的日志容器,用于记录每个线程。 线程A放入MDC.put(key,A),线程B放入MDC.put(key,B),在线程A中MDC.get(key)返回A,在线程B中MCD.get(key)返回B。所以只有放置值的线程可以获取它。 slf4j是它的接口,log4j2是MDC的实现,最好用slf4j库来获取,它的实现是log4j2,没有log4j2 slf4j是不行的。我建议你使用sfl4j来编码,它可以将你的代码与实现log4j2或logback解耦,只依赖slf4j的外观,以后很容易改变你的实现。