解决SlF4J配置冲突警告:【SLF4J: Class path contains multiple SLF4J providers】

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]

解决SlF4J配置冲突警告:【SLF4J: Class path contains multiple SLF4J providers】_第1张图片

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

执行结果如下:

解决SlF4J配置冲突警告:【SLF4J: Class path contains multiple SLF4J providers】_第2张图片

确实看到了,在com.github.lookfirst:sardine:jar:5.12:compile依赖里面包含着org.slf4j:slf4j-simple:jar:2.0.9:compile

3、解决办法

我们找到sharding的pom依赖,将slf4j-simple排除下就解决了。

 
            com.github.lookfirst
            sardine
            5.12
            
                
                    org.slf4j
                    slf4j-simple
                
            
 

重新启动确实没有了警告

解决SlF4J配置冲突警告:【SLF4J: Class path contains multiple SLF4J providers】_第3张图片

 

4、总结

SLF4J :Class path contains multiple SLF4J bindings.这样的异常情况还有很多,这是一大类问题,解决的思路都是一样的:分析pom依赖,找到依赖冲突的jar,在对应的pom中将期排除就ok。
 

 

 

 

 

 

 

 

 

你可能感兴趣的:(故障分析,java,开发语言)