log4j2日志不打印排查过程及处理

Posted 四阿哥胤禛

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了log4j2日志不打印排查过程及处理相关的知识,希望对你有一定的参考价值。

记录本次问题排查过程及处理方案

问题描述

本地环境log4j2日志正常打印、应用上生产之后发现生产环境的日志不打印,检查生产环境日志发现,只有tomcat生成的catalina-xxx.log文件中有tomcat启动日志,应用程序中通过log4j2打印的日志并没有生成。

问题思考

对于这种情况,不同环境下出现不同的表现,收集两个环境中tomcat启动日志,在开发环境下通过tomcat启动时加载类信息查看到以下提示,初步诊断,是由于包依赖冲突导致log4j2日志失效。

log4j2日志不打印排查过程及处理

SLF4J: Class path contains multiple SLF4J bindings.SLF4J: Found binding in [jar:file:/C:/Users/user/.m2/repository/org/apache/logging/log4j/log4j-slf4j-impl/2.10.0/log4j-slf4j-impl-2.10.0.jar!/org/slf4j/impl/StaticLoggerBinder.class]SLF4J: Found binding in [jar:file:/C:/Users/user/.m2/repository/org/slf4j/slf4j-simple/1.7.25/slf4j-simple-1.7.25.jar!/org/slf4j/impl/StaticLoggerBinder.class]SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.SLF4J: Actual binding is of type [org.apache.logging.slf4j.Log4jLoggerFactory]

问题处理

如何查找到冲突类

经过上面的分析,我们需要去除依赖org.slf4j.slf4j-simple,那么如何找到这个依赖包是属于哪个dependecy?

这里介绍两种方法查看相关依赖。

1.通过idea右侧maven查看

log4j2日志不打印排查过程及处理


2.执行命令mvn dependency:tree

log4j2日志不打印排查过程及处理

以上两种方式都可以查看到项目的所有依赖及子依赖。在我的案例中,查找到org.slf4j.slf4j-simplecom.baidu.aip:java-sdk的子依赖

问题找到了,这时候我们需要做的是将com.baidu.aip:java-sdk的子依赖org.slf4j.slf4j-simple从项目中移除,如下:


以上是关于log4j2日志不打印排查过程及处理的主要内容,如果未能解决你的问题,请参考以下文章

Log4j2异步日志背后的数字

springboot应用程序不打印Info日志

springboot应用程序不打印Info日志

风靡IT圈的史诗级漏洞log4j2的产生原理及复现

log4j2滚动删除丢日志的问题排查

EasyNVR日志中堆栈信息打印为字节代码排查及优化