SpringBoot2 启动报SLF4J: Class path contains multiple SLF4J bindings.

背景

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操作具体如下:

       
            org.springframework.boot
            spring-boot-starter
            
                
                    logback-classic
                    ch.qos.logback
                
            
        

再次启动就可发现提示已经没有了。

你可能感兴趣的:(SpringBoot2 启动报SLF4J: Class path contains multiple SLF4J bindings.)