LocationAwareLogger 上的 SLF4J NoSuchMethodError
Posted
技术标签:
【中文标题】LocationAwareLogger 上的 SLF4J NoSuchMethodError【英文标题】:SLF4J NoSuchMethodError on LocationAwareLogger 【发布时间】:2012-01-05 08:37:33 【问题描述】:这是一个以前被问过的问题,但不幸的是,似乎没有任何解决方案对我有用。我正面临这个异常(带有删节的堆栈跟踪):
java.lang.NoSuchMethodError: org.slf4j.spi.LocationAwareLogger.log(Lorg/slf4j/Marker;Ljava/lang/String;ILjava/lang/String;[Ljava/lang/Object;Ljava/lang/Throwable;)V
at org.apache.commons.logging.impl.SLF4JLocationAwareLog.debug(SLF4JLocationAwareLog.java:133)
at org.apache.http.impl.conn.tsccm.ThreadSafeClientConnManager$1.getConnection(ThreadSafeClientConnManager.java:221)
at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:401)
at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:820)
在使用命令行 Maven 编译以及部署到 Tomcat 时会发生这种情况。它在 IntelliJ IDEA 中运行良好。
通常我认为这是由多个版本的 SLF4J 库正在使用引起的。但是 Maven 依赖树在单个版本中显示了所有 slf4j 库:
..$ mvn dependency:tree | grep slf4j
[INFO] +- org.slf4j:slf4j-simple:jar:1.6.4:compile
[INFO] | \- org.slf4j:slf4j-api:jar:1.6.4:compile
[INFO] +- org.slf4j:slf4j-api:jar:1.6.4:compile
[INFO] +- org.slf4j:jcl-over-slf4j:jar:1.6.4:compile
[INFO] +- org.slf4j:slf4j-simple:jar:1.6.4:compile
我什至确保 ~/.m2/repository 中没有其他 JAR
也没有对公共日志库的引用(我将它们全部排除在依赖树中。
我该如何解决这个问题?我的想法不多了。
编辑:这里要求完整的依赖关系,首先是父 POM:
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator</artifactId>
<version>$org.hibernate.validator.version</version>
<exclusions>
<!-- Exclude SLF4j to avoid version conflicts (we have 1.6.2, this drags in 1.6.1) -->
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator-annotation-processor</artifactId>
<version>$org.hibernate.validator.version</version>
</dependency>
<dependency>
<groupId>javax.validation</groupId>
<artifactId>validation-api</artifactId>
<version>1.0.0.GA</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>$org.springframework.version</version>
<exclusions>
<!-- Exclude Commons Logging in favor of SLF4j -->
<exclusion>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>$org.springframework.version</version>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-config</artifactId>
<version>$org.springframework.version</version>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-core</artifactId>
<version>$org.springframework.version</version>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-web</artifactId>
<version>$org.springframework.version</version>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-taglibs</artifactId>
<version>$org.springframework.version</version>
</dependency>
<dependency>
<groupId>javax.inject</groupId>
<artifactId>javax.inject</artifactId>
<version>1</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.8.2</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>$org.slf4j.backend</artifactId>
<version>$org.slf4j.version</version>
</dependency>
<dependency>
<groupId>org.hsqldb</groupId>
<artifactId>hsqldb</artifactId>
<version>2.2.4</version>
</dependency>
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.1.2</version>
</dependency>
<dependency>
<groupId>joda-time</groupId>
<artifactId>joda-time</artifactId>
<version>2.0</version>
</dependency>
<dependency>
<groupId>joda-time</groupId>
<artifactId>joda-time-jsptags</artifactId>
<version>1.0.2</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.1</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>postgresql</groupId>
<artifactId>postgresql</artifactId>
<version>9.0-801.jdbc4</version>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>3.0.1</version>
</dependency>
</dependencies>
</dependencyManagement>
然后是失败的模块:
<dependencies>
// client specific dependencies skipped //
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>10.0.1</version>
</dependency>
<!-- Spring -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<exclusions>
<!-- Exclude Commons Logging in favor of SLF4j -->
<exclusion>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-config</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-core</artifactId>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-web</artifactId>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-taglibs</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>javax.inject</groupId>
<artifactId>javax.inject</artifactId>
</dependency>
<dependency>
<groupId>cglib</groupId>
<artifactId>cglib</artifactId>
<version>2.2.2</version>
</dependency>
<!-- Logging -->
<dependency>
<groupId>net.sf.opencsv</groupId>
<artifactId>opencsv</artifactId>
<version>2.0</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>$org.slf4j.version</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
<version>$org.slf4j.version</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>$org.slf4j.backend</artifactId>
<version>$org.slf4j.version</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.16</version>
</dependency>
<!-- Joda Time -->
<dependency>
<groupId>joda-time</groupId>
<artifactId>joda-time</artifactId>
</dependency>
<dependency>
<groupId>joda-time</groupId>
<artifactId>joda-time-jsptags</artifactId>
<scope>runtime</scope>
</dependency>
<!-- Servlet -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
</dependency>
<dependency>
<groupId>com.google.visualization</groupId>
<artifactId>visualization-datasource</artifactId>
<version>1.0.2</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>1.0.2</version>
</dependency>
<dependency>
<groupId>commons-dbcp</groupId>
<artifactId>commons-dbcp</artifactId>
<version>1.4</version>
</dependency>
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-mapper-asl</artifactId>
<version>1.9.0</version>
</dependency>
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.1</version>
</dependency>
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.2.2</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.7</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.7</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml-schemas</artifactId>
<version>3.7</version>
</dependency>
<dependency>
<groupId>postgresql</groupId>
<artifactId>postgresql</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<scope>test</scope>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
</dependency>
</dependencies>
这些是在父级上设置的属性:
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<org.hibernate.validator.version>4.2.0.Final</org.hibernate.validator.version>
<org.slf4j.backend>slf4j-simple</org.slf4j.backend>
<org.slf4j.version>1.6.4</org.slf4j.version>
<org.springframework.version>3.0.5.RELEASE</org.springframework.version>
</properties>
不过,鉴于我最近的实验,这似乎不是与项目文件有关的问题。我试图将问题“平分”,但回溯数周后,我找不到有效的版本。其中一些正在生产系统中运行,因此不太可能是代码更改导致此问题。
【问题讨论】:
你能分享你 pom.xml 的依赖吗? 【参考方案1】:NoSuchMethodError 的 javadocs 说,
通常,编译器会捕获此错误;这个错误可以 仅当类的定义发生不兼容的更改时才会在运行时发生。
所以这可能是由于加载的 slf4j 版本不兼容造成的。与其查看您的类路径并猜测类的加载位置,不如按照here 的描述找到您的类的加载位置。
打印出 org.slf4j.spi.LocationAwareLogger
、org.apache.commons.logging.impl.SLF4JLocationAwareLog
和 org.slf4j.Marker
的加载位置。
【讨论】:
我应该考虑询问类加载器。事实证明auskey.abr.gov.au 是罪魁祸首:当我 5 天前安装他们的密钥时,他们将 1.5.8 slf4j 的副本转储到 /usr/java/packages/lib/ext/ 中。那里有更多可怕的东西(log4j、bcmail、jaxb...)——我需要设置一个单独的 JRE。不过,我希望 slf4j 停止破坏二进制兼容性。 安装auskey后正好遇到这个问题!感谢@PeterBecker 的评论。 我可以导入这个答案中提到的类(因为在 IDE 中不会抱怨找不到它们),但是当我尝试运行应该显示它们的代码时从中加载,我得到一个编译错误:package does not exist
和 cannot find symbol
。然而slf4j
在我的类路径中,而且只有一个版本。
@payne 我会使用干净的 JRE(已经有一段时间了),但这是一个与您不同的问题。您可能依赖于 IDE 的库集,而不是运行时类路径。它可能需要自己的问题。【参考方案2】:
我收到了相同的错误消息,但解决方案对我来说不同。我必须 删除 以遵循 maven pom 的依赖项:
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
<version>1.6.1</version>
</dependency>
之后错误消失了,一切都对我有用。
【讨论】:
我在父 pom 中将其添加为provided
依赖项
如果它一开始就在那里,那可能是有原因的?【参考方案3】:
一个解决方案。
在eclipse目录上验证:configuration\org.eclipse.equinox.simpleconfigurator\bundles.info
slf4j 没有了
【讨论】:
【参考方案4】:做
mvn clean 依赖:tree -DskipTests;
删除“org.slf4j”的所有依赖项,除了一个(最高的一个“)为
<dependency>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>2.6</version>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-jdk14</artifactId>
</exclusion>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
</exclusion>
</exclusions>
</dependency>
【讨论】:
【参考方案5】:我们遇到了类似的问题,结果我们在类路径中有 2 个不兼容的 slf4j jar 版本。 类路径有以下 2 个不兼容的版本。从类路径中删除较低版本后,问题得到解决。
slf4j-api-1.6.1.jar slf4j-log4j12-1.6.1.jar
slf4j-api-1.5.11.jar slf4j-log4j12-1.5.11.jar
【讨论】:
【参考方案6】:解决了!!!
我依赖于另一个使用 JavaDoc
插件的项目。
JavaDoc
插件内部使用Maven-core
和Maven-core-2.2.1
使用jcl-over-slf4j: 1.5.6
。
Maven-core
是父级 jar。
现在,由于这个JCL
jar,我遇到了这个问题。
因此,我将其从weblogic
(或您可能使用的任何服务器)的lib
文件夹中删除。
唉!问题已解决。
注意 1:- 您也可以使用 Maven 的 <exclusion>
标签从 JavaDoc
(或任何其他插件)中删除此依赖项以解决此问题。
注意 2:- 使用 POM 中的 Dependency Hierarchy
选项卡查看是否存在任何此类旧的 SLF4J
jar。并去掉其余部分,只保留一个版本。
希望对您有所帮助..
【讨论】:
【参考方案7】:当您的依赖项都使用相同的传递依赖项时,通常会发生这种情况。这意味着您的两个依赖项(或您的应用程序和传递依赖项)都在内部使用不同版本的 SLF4J。但是你的应用只能同时使用一个版本的类,所以它必须选择(不知道这里的规则......随机?)
要解决这个问题,你通常需要做一个mvn dependency:tree
来查看哪些使用不同版本的SLF4J。
添加此依赖项为我解决了问题
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.25</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.5</version>
</dependency>
【讨论】:
【参考方案8】:我的 pom 文件中有石英调度程序,其中包括 slf4j,所以我排除了它:
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
并且工作了!
【讨论】:
以上是关于LocationAwareLogger 上的 SLF4J NoSuchMethodError的主要内容,如果未能解决你的问题,请参考以下文章
springMvc引入slf4j报错,org.slf4j.spi.LocationAwareLogger.log如何解决?
java.lang.NoSuchMethodError: org.slf4j.spi.LocationAwareLogger.log(Lorg/slf4j/Marker;Ljava/lang/Stri
Android 应用程序开发上的 SL4A 与 Ruboto