记录本次问题排查过程及处理方案
问题描述
本地环境log4j2日志正常打印、应用上生产之后发现生产环境的日志不打印,检查生产环境日志发现,只有tomcat生成的catalina-xxx.log文件中有tomcat启动日志,应用程序中通过log4j2打印的日志并没有生成。
问题思考
对于这种情况,不同环境下出现不同的表现,收集两个环境中tomcat启动日志,在开发环境下通过tomcat启动时加载类信息查看到以下提示,初步诊断,是由于包依赖冲突导致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查看
2.执行命令mvn dependency:tree
以上两种方式都可以查看到项目的所有依赖及子依赖。在我的案例中,查找到org.slf4j.slf4j-simple
是com.baidu.aip:java-sdk
的子依赖。
问题找到了,这时候我们需要做的是将com.baidu.aip:java-sdk
的子依赖org.slf4j.slf4j-simple
从项目中移除,如下:
文章转载自四阿哥胤禛,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【专家观点】罗敏:从理论到真实SQL,感受DeepSeek如何做性能优化
墨天轮编辑部
1257次阅读
2025-03-06 16:45:38
【专家有话说第五期】在不同年龄段,DBA应该怎样规划自己的职业发展?
墨天轮编辑部
1250次阅读
2025-03-13 11:40:53
2025年2月国产数据库大事记
墨天轮编辑部
976次阅读
2025-03-05 12:27:34
2025年2月国产数据库中标情况一览:GoldenDB 3500+万!达梦近千万!
通讯员
863次阅读
2025-03-06 11:40:20
2月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
448次阅读
2025-03-13 14:38:19
AI的优化能力,取决于你问问题的能力!
潇湘秦
416次阅读
2025-03-11 11:18:22
优炫数据库成功应用于国家电投集团青海海南州新能源电厂!
优炫软件
337次阅读
2025-03-21 10:34:08
达梦数据与法本信息签署战略合作协议
达梦数据
286次阅读
2025-03-06 09:26:57
国产化+性能王炸!这套国产方案让 3.5T 数据 5 小时“无感搬家”
YMatrix
271次阅读
2025-03-13 09:51:26
磐维数据库对外门户全新升级!
磐维数据库
237次阅读
2025-03-04 15:32:59