org.slf4j.impl.Log4jLoggerFactory cannot be cast to ch.qos.logback.classic.LoggerContext

今天把服务部署到测试环境但是tomcat启动报错,报错内容如下图:
这里写图片描述

org.slf4j.impl.Log4jLoggerFactory cannot be cast to ch.qos.logback.classic.LoggerContext,从这句话字面可以看出Log4jLoggerFactory不可以强转成LoggerContext,也就是log4J和logback冲突了。

程序classpath里面使用的是log4J,但是在引用的kafka这个jar包里面使用的是logback。
这里写图片描述

从上图可以看出,slf4j-log4j12-1.6.4.jar和logback-classic-1.0.9.jar中StaticLoggerBinder路径一样,因此加载容易出错。所以我本地始终可以启动成功,但是一上测试之后就出了问题。

那么怎么解决这个问题呢,很简单,删除slf4j-log4j12-1.6.4.jar这个jar包即可。如果是maven项目,在pom.xml文件中加上

<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
</exclusions>
本站公众号
   欢迎关注本站公众号,获取更多程序园信息
开发小院