背景
SpringBoot项目在启动时报 Class path contains multiple SLF4J bindings。
问题排查
根据字面意思理解:slf4j绑定了多个实现,解决方式很简单自然就是只绑定一个实现就好了,看详细日志信息,如下:
SLF4J: Found binding in [jar:file:/Users/admin/data/mavenRepo/org/apache/logging/log4j/log4j-slf4j-impl/2.11.2/log4j-slf4j-impl-2.11.2.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/Users/admin/data/mavenRepo/ch/qos/logback/logback-classic/1.2.3/logback-classic-1.2.3.jar!/org/slf4j/impl/StaticLoggerBinder.class]
日志指出绑定了log4j和logback两种实现,去掉一种就行了,有的小伙伴可能会疑问,我只引入了log4j一种实现啊,这里的logback哪里来的,实际上是logback是springboot2的默认日志实现,取消依赖就好了,maven操作具体如下:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<exclusions>
<exclusion>
<artifactId>logback-classic</artifactId>
<groupId>ch.qos.logback</groupId>
</exclusion>
</exclusions>
</dependency>
再次启动就可发现提示已经没有了。