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

2024-01-08 00:21:25

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]

583f0460ad2340d985e7a649250324cf.png

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

执行结果如下:

0a74bd2b685646e0970e13e7edf7a21a.png

确实看到了,在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>

重新启动确实没有了警告

1707bac1bae74ba9b195f807c1781e78.png

4、总结

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

文章来源:https://blog.csdn.net/weixin_44543482/article/details/135433950
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。