1、问题背景
最近在启动Springboot的时候出现了SLF4J相关的报红警告,虽然是不影响程序运行,但是作为一个有着代码洁癖的人看的是真难受。
警告信息如下:
SLF4J: Class path contains multiple SLF4J providers.
SLF4J: Found provider [ch.qos.logback.classic.spi.LogbackServiceProvider@2459319c]
SLF4J: Found provider [org.slf4j.simple.SimpleServiceProvider@ffaaaf0]
SLF4J: See https://www.slf4j.org/codes.html#multiple_bindings for an explanation.
SLF4J: Actual provider is of type [ch.qos.logback.classic.spi.LogbackServiceProvider@2459319c]
2、分析过程
2.1、分析错误警告
警告信息在那放着,首先我们应该逐行解读,看看能否找到解决问题的途径。
1、从第一行SLF4J: Class path contains multiple SLF4J providers.我们能知道是在路径下发现了多个SLF4J的绑定。能很容易看出来SLF4J相关的依赖出现了冲突,
后来查阅了一些资料,才知道原来SLF4J本身并没有实现日志相关的功能,而是通过与日志的实现类进行关联绑定才能完成日志的打印等。
2、从警告的第2行和第3行,我们也能看到确实绑定了两个,分别是以下两个ch.qos.logback.classic.spi.LogbackServiceProvider@2459319c
org.slf4j.simple.SimpleServiceProvider@ffaaaf0
3、从日志的最后一行Actual provider is of type [ch.qos.logback.classic.spi.LogbackServiceProvider@2459319c],已经告诉我们了,程序中实际用的是ch.qos.logback.classic.spi.LogbackServiceProvider@2459319
分析了错误警告之后,那就简单了,我们是不是只要知道程序里哪里引用了 “org.slf4j.simple.SimpleServiceProvider@ffaaaf0”这个相关的依赖,并且将他从pom中移除掉,是不是就解决这个问题了呢?那就试试吧。
2.2、分析依赖
我们在当前的pom文件所有的目录下,执行以下命令,就会把所有的依赖以树形的结构展现出来
$ mvn dependency:tree
执行结果如下:
确实看到了,在com.github.lookfirst:sardine:jar:5.12:compile依赖里面包含着org.slf4j:slf4j-simple:jar:2.0.9:compile
3、解决办法
我们找到sharding的pom依赖,将slf4j-simple排除下就解决了。
<dependency>
<groupId>com.github.lookfirst</groupId>
<artifactId>sardine</artifactId>
<version>5.12</version>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-simple</artifactId>
</exclusion>
</exclusions>
</dependency>
重新启动确实没有了警告
4、总结
SLF4J :Class path contains multiple SLF4J bindings.这样的异常情况还有很多,这是一大类问题,解决的思路都是一样的:分析pom依赖,找到依赖冲突的jar,在对应的pom中将期排除就ok。