日志记录框架不兼容
2022-08-31 09:38:24
我正在构建一个小型Java应用程序,并希望使用logback进行日志记录。
我的应用依赖于较旧的项目,该项目通过以下方式进行日志记录
org.apache.commons | com.springsource.org.apache.commons.logging | 1.1.1
...所以我的计划是使用
org.slf4j | jcl-over-slf4j | 1.5.6
...将 JCL 日志记录重定向到
org.slf4j | slf4j-api | 1.6.0
...并最终
ch.qos.logback | logback-classic | 0.9.22
ch.qos.logback | logback-core | 0.9.22
所以我的应用程序可以通过其slf4j API通过logback登录,而旧的库代码可以通过重定向登录到相同的位置。
唉,这导致
java.lang.NoSuchMethodError: org.slf4j.spi.LocationAwareLogger.log(Lorg/slf4j/Marker;Ljava/lang/String;ILjava/lang/String;Ljava/lang/Throwable;)V
at org.apache.commons.logging.impl.SLF4JLocationAwareLog.info(SLF4JLocationAwareLog.java:141)
我已经在其中一些jar上尝试了更高和更低的verrision数字,并且还挖掘了API文档等...但我无法找到并解决问题。
请帮忙吗?
虽然 logback 被认为是“战略性”日志记录框架,但我最终在哪种日志记录机制方面有一些余地。不过,我希望使用logback或log4j,而且我肯定希望通过通用配置将旧项目的日志记录合并到“新”日志记录框架最终出现的任何位置。