【发布时间】:2021-10-07 01:02:08
【问题描述】:
我有一个要部署在 jboss/wildfly 上的 war 文件。战争在其 WEB-INF/lib 目录中包含许多 jar。其中一些 jar 包含相同类的冲突(或至少不同)版本。
例如, 有一罐 feign 来自我们遗留代码中的两个来源并在 maven 中定义,因此它可能在一个或其他类中使用,我无法删除任何类。
<dependency>
<groupId>io.github.openfeign</groupId>
<artifactId>feign-okhttp</artifactId>
<version>10.1.0</version>
</dependency>
这带来了 feign-core:10.2.3 的 Feign Dependency
<dependency>
<!-- Required to use PATCH -->
<groupId>com.netflix.feign</groupId>
<artifactId>feign-httpclient</artifactId>
<version>8.18.0</version>
</dependency>
这带来了 feign-core:8.18.0 的 Feign Dependency
两者都有一个响应类,但其中一个没有代码所需的特定 create 方法。
问题是当 jboss/wildfly 部署这个 war 文件时,它会将所有依赖项带到 WEB-INF/lib 文件夹中,并且两个 jar 都在那里,这里的 jar 文件的顺序/优先级是什么?如果 classloader 选择了第一个 jar,它会抛出错误,否则它会正常工作。
在第一种情况下,它会抛出此错误:
java.lang.NoSuchMethodError: feign.Response.create(ILjava/lang/String;Ljava/util/Map;Lfeign/Response$Body;)Lfeign/Response;
我们怎样才能避免这种情况?
【问题讨论】:
标签: java maven jboss wildfly classloader