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>
  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,"logback-classic Failed to load class "org.slf4j.impl.StaticLoggerBinder"." 是一个错误信息,表明在使用logback-classic日志框架时,无法加载org.slf4j.impl.StaticLoggerBinder类。这个错误通常发生在缺少相关依赖或配置不正确的情况下。 解决这个问题的方法有以下几种: 1. 确保正确配置了相关依赖:检查项目的依赖配置文件(如pom.xml或build.gradle)中是否包含了正确的logback-classic依赖。例如,在Maven项目中,可以添加以下依赖: ```xml <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-classic</artifactId> <version>1.2.3</version> </dependency> ``` 2. 检查类路径:确保logback-classic的jar包已经正确添加到项目的类路径中。可以通过查看项目的构建配置或IDE的项目设置来确认。 3. 检查日志配置文件:logback-classic需要一个配置文件来指定日志输出的方式和级别。确保logback.xml或logback.groovy配置文件存在,并且配置正确。可以参考logback官方文档来了解如何正确配置日志文件。 4. 检查其他日志框架的冲突:如果项目中同时使用了其他日志框架(如log4j或java.util.logging),可能会导致冲突。在这种情况下,可以尝试移除其他日志框架的依赖或者进行适当的配置。 5. 检查SLF4J的版本兼容性:确保使用的logback-classic版本与SLF4J的版本兼容。可以在SLF4J的官方网站上查找版本兼容性信息。 请注意,以上方法是常见的解决方案,但具体解决方法可能因项目配置和环境而异。如果问题仍然存在,建议查阅logback-classicSLF4J的官方文档,或者在相关的开发社区中寻求帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值