解决SLF4J警告信息Class path contains multiple SLF4J bindings,logback与log4j包冲突
2020年04月15日 12:00:10 · 本文共 1,251 字阅读时间约 4分钟 · 16,852 次浏览运行日志中出现SLF4J警告信息Class path contains multiple SLF4J bindings,例如在SpringBoot中引用了sdk.renfei.net以后就会出现,其实这个是一个Jar包冲突的情况,只需要排除冲突的Jar包即可。
报错信息如下:
SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/Users/neil/.m2/repository/ch/qos/logback/logback-classic/1.2.3/logback-classic-1.2.3.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/Users/neil/.m2/repository/org/slf4j/slf4j-log4j12/1.7.30/slf4j-log4j12-1.7.30.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 [ch.qos.logback.classic.util.ContextSelectorStaticBinder]
原因分析
报错信息意思是说logback-classic 包和slf4j-log4j12 包,关于org/slf4j/impl/StaticLoggerBinder.class 这个类发生了冲突。发生这个错误的原因,首先logback日志的开发者和log4j的开发者据说是一波人,而SpringBoot新版默认日志插件是logback,而且很多的第三方工具都含有log4j的引入。例如sdk.renfei.net就使用了log4j日志插件,所以,基本上SpringBoot项目,如果不注意,肯定会出现这种冲突。
其中隐患
虽然可能并不影响项目启动,但是在打成Jar包以后,在线上可能会出现启动报错的情况,所以我们尽量把这个问题解决,避免启动失败的隐患。
问题解决
解决的办法也很简单,只需要排除冲突的Jar包即可,如果你用的是logback日志,一定要排除slf4j-log4j12包,不要排除logback-classic包,因为我决定主要使用logback,所以要排除掉log4j的slf4j-log4j12包,找到谁在依赖slf4j-log4j12包,然后排除它,在引用这个依赖的pom文件中dependency节点增加exclusions进行排除:
<dependency>
<groupId>net.renfei</groupId>
<artifactId>sdk</artifactId>
<version>${renfeisdk.version}</version>
<exclusions>
<!--排除slf4j-log4j12-->
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
</exclusions>
</dependency>
先找到Maven管理菜单,点击“Show Dependenceies”
然后会得到一个依赖图,我们找到冲突的包,就可以知道这个包是谁引入进来的,从而去排除
版权声明:本文为博主「任霏」原创文章,遵循 CC BY-NC-SA 4.0 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.renfei.net/posts/1003353
相关推荐
猜你还喜欢这些内容,不妨试试阅读一下以下内容均由网友提交发布,版权与真实性无法查证,请自行辨别。
- 前后端分离项目接口数据加密的秘钥交换逻辑(RSA、AES)
- OmniGraffle 激活/破解 密钥/密匙/Key/License
- Redis 未授权访问漏洞分析 cleanfda 脚本复现漏洞挖矿
- CleanMyMac X 破解版 [TNT] 4.6.0
- OmniPlan 激活/破解 密钥/密匙/Key/License
- 人大金仓 KingbaseES V8 R3 安装包、驱动包和 License 下载地址
- Parallels Desktop For Mac 16.0.1.48911 破解版 [TNT]
- Parallels Desktop For Mac 15.1.4.47270 破解版 [TNT]
- Sound Control 破解版 2.4.2
- CleanMyMac X 破解版 [TNT] 4.6.5
- 博客完全迁移上阿里云,我所使用的阿里云架构
- 微软确认Windows 10存在bug 部分电脑升级后被冻结
- 大佬们在说的AQS,到底啥是个AQS(AbstractQueuedSynchronizer)同步队列
- 比特币(BTC)钱包客户端区块链数据同步慢,区块链数据离线下载
- Java中说的CAS(compare and swap)是个啥
- 小心免费主题!那些WordPress主题后门,一招拥有管理员权限
- 强烈谴责[wamae.win]恶意反向代理我站并篡改我站网页
- 讨论下Java中的volatile和JMM(Java Memory Model)Java内存模型
- 新版个人网站 NEILREN4J 上线并开源程序源码
- 我站近期遭受到恶意不友好访问攻击公告