背景
SpringBoot項目在啟動時報 Class path contains multiple SLF4J bindings。
問題排查
根據(jù)字面意思理解:slf4j綁定了多個實現(xiàn),解決方式很簡單自然就是只綁定一個實現(xiàn)就好了,看詳細日志信息,如下:
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兩種實現(xiàn),去掉一種就行了,有的小伙伴可能會疑問,我只引入了log4j一種實現(xiàn)啊,這里的logback哪里來的,實際上是logback是springboot2的默認日志實現(xiàn),取消依賴就好了,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>
再次啟動就可發(fā)現(xiàn)提示已經(jīng)沒有了。