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

  • Post author:
  • Post category:其他


今天把服务部署到测试环境但是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>



版权声明:本文为a18716374124原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。