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

文章讲述了在启动Springboot项目时遇到SLF4J警告的问题,涉及到了类路径下的多SLF4J绑定。通过分析错误警告,发现是由于com.github.lookfirst:sardine依赖中的slf4j-simple引起的。解决方法是找出冲突依赖并将其在pom.xml中排除,确保程序只使用一个SLF4J实现。
摘要由CSDN通过智能技术生成

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。

  • 34
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
SLF4J: Class path contains multiple SLF4J providers是一个错误信息,表示在项目的classpath中存在多个SLF4J提供者。这个问题通常会导致SLF4J无法确定使用哪个提供者,从而引发错误。 解决这个问题的方法是删除或排除冲突SLF4J提供者。可以通过以下步骤来解决这个问题: 1. 首先,需要确定项目的依赖关系,尤其是与日志相关的依赖项。查看项目的pom.xml文件或构建配置文件,找到与SLF4J相关的依赖项。 2. 接下来,需要确定哪些依赖项导致了冲突。查找冲突SLF4J提供者,可以在错误信息中找到类似"Found binding in"的内容,它会列出存在冲突的路径以及提供者的名称。 3. 一旦确定了冲突的提供者,可以选择将其中一个提供者从项目中移除。这可以通过在项目配置文件中排除依赖项或手动删除相关的jar文件来实现。 4. 如果移除冲突的提供者后仍然存在问题,可能需要查看项目的其他依赖项,确保它们与SLF4J的版本兼容。 总的来说,当出现SLF4J: Class path contains multiple SLF4J providers错误时,需要检查项目的依赖关系,找出冲突SLF4J提供者并进行相应的调整。这样可以确保SLF4J能够正常工作并连接到正确的日志实现。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [IDEA运行报错:slf4j:Class path contains multiple SLF4J bindings. SLF4J: Found binding in [jar:file:/...](https://blog.csdn.net/qq_44425201/article/details/120863321)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [SLF4J(二) - SLF4J绑定了多个实现类的错误是怎么一回事儿?源码解析](https://blog.csdn.net/sweetyi/article/details/104633321)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小徐很努力

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值