我正在开发一个项目,使用Maven进行依赖/构建/任何事情(项目生命周期管理或某事),我正在使用Eclipse进行开发和测试。
该项目使用Vert.x(最新版),我正在尝试使用Hazelcast进行一些集群管理,但我遇到了一个错误,其中包含Vert.x声明的Hazelcast版本作为依赖项(3.6.3)和解决方案显然是升级到更新版本。
我在pom.xml
中添加了更新的Hazelcast依赖关系:
<dependency>
<groupId>com.hazelcast</groupId>
<artifactId>hazelcast</artifactId>
<version>[3.7,)</version>
</dependency>
并且maven确实更新了依赖项(实际上Eclipse一旦我保存pom.xml
文件就称为maven更新 - 非常整洁),所以我得到了依赖树:
$ mvn dependency:tree
[INFO] Scanning for projects...
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] Building project 3.8.4
[INFO] ------------------------------------------------------------------------
[WARNING] The POM for jfree:jfreechart:jar:1.0.8 is missing, no dependency information available
[INFO]
[INFO] --- maven-dependency-plugin:2.8:tree (default-cli) @ project ---
[INFO] my.group:project:jar:3.8.4
[INFO] +- some.private.dep ...
[INFO] | +- org.junit:junit4-engine:jar:5.0.0-ALPHA:compile (version selected from constraint [4,))
[INFO] | | \- org.junit:junit-engine-api:jar:5.0.0-ALPHA:compile
[INFO] | | +- org.junit:junit-commons:jar:5.0.0-ALPHA:compile
[INFO] | | \- org.opentest4j:opentest4j:jar:1.0.0-ALPHA:compile
[INFO] | +- io.vertx:vertx-hazelcast:jar:3.3.3:compile (version selected from constraint [3.0.0,))
[INFO] | \- io.vertx:vertx-web:jar:3.4.0.Beta1:compile (version selected from constraint [3.0.0,))
[INFO] | \- io.vertx:vertx-auth-common:jar:3.4.0.Beta1:compile
[INFO] +- io.vertx:vertx-core:jar:3.4.0.Beta1:compile
[INFO] | +- io.netty:netty-common:jar:4.1.8.Final:compile
[INFO] | +- io.netty:netty-buffer:jar:4.1.8.Final:compile
[INFO] | +- io.netty:netty-transport:jar:4.1.8.Final:compile
[INFO] | +- io.netty:netty-handler:jar:4.1.8.Final:compile
[INFO] | | \- io.netty:netty-codec:jar:4.1.8.Final:compile
[INFO] | +- io.netty:netty-handler-proxy:jar:4.1.8.Final:compile
[INFO] | | \- io.netty:netty-codec-socks:jar:4.1.8.Final:compile
[INFO] | +- io.netty:netty-codec-http:jar:4.1.8.Final:compile
[INFO] | +- io.netty:netty-codec-http2:jar:4.1.8.Final:compile
[INFO] | +- io.netty:netty-resolver:jar:4.1.8.Final:compile
[INFO] | \- io.netty:netty-resolver-dns:jar:4.1.8.Final:compile
[INFO] | \- io.netty:netty-codec-dns:jar:4.1.8.Final:compile
[INFO] +- junit:junit:jar:4.12:test
...
[INFO] +- com.hazelcast:hazelcast:jar:3.8-EA:compile
[INFO] \- org.slf4j:slf4j-jdk14:jar:1.7.22:compile
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 2.785 s
[INFO] Finished at: 2017-02-06T09:52:46+02:00
[INFO] Final Memory: 25M/435M
[INFO] ------------------------------------------------------------------------
当我运行mvn package
来创建阴影Jar时,我会获得正确版本的Hazelcast。
问题在于,如果我为运行项目或其单元测试创建Eclipse启动配置,它会将旧版本的Hazelcast以及新版本的Hazelcase插入到类路径中 - 这是一个示例命令行来自单元测试正在运行:
/usr/lib/jvm/java-8-openjdk-amd64/bin/java -agentlib:jdwp=transport=dt_socket,suspend=y,address=localhost:33123 -ea -Dfile.encoding=UTF-8
-classpath ...:
$HOME/.m2/repository/io/vertx/vertx-hazelcast/3.3.3/vertx-hazelcast-3.3.3.jar:
$HOME/.m2/repository/com/hazelcast/hazelcast/3.6.3/hazelcast-3.6.3.jar:
...
$HOME/.m2/repository/com/hazelcast/hazelcast/3.8-EA/hazelcast-3.8-EA.jar:
...
-version 3 -port 38387 -testLoaderClass org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader
-loaderpluginname org.eclipse.jdt.junit4.runtime
-classNames my.group.project.SomeTest
现在因为两个版本都被加载到类路径中,第一个版本(较旧版本)“获胜”,我得到了错误,而不是获得更新的固定版本。
启动配置“Classpath”选项卡看起来很标准:
+ Bootstrap Entries
\- JRE System Library
+ User Enties
\- project
\- Maven Dependencies
“Project Explorer”视图中的“Maven Dependencies”“文件夹”仅显示较新的Hazelcast版本。
发生了什么事?
更新
根据评论中的讨论,我在pom.xml
文件中添加了排除项,以防止vertx-hazelcast
添加旧的hazelcast
依赖项。因为vertx-hazelcast
是从另一个(私有)依赖项加载的,所以新设置更复杂,看起来像这样:
<dependency>
<groupId>some.private</groupId>
<artifactId>dependency</artifactId>
<version>[1.3,)</version>
<exclusions>
<exclusion>
<groupId>io.vertx</groupId>
<artifactId>vertx-hazelcast</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>io.vertx</groupId>
<artifactId>vertx-core</artifactId>
<version>[3.0.0,)</version>
</dependency>
<dependency>
<groupId>com.hazelcast</groupId>
<artifactId>hazelcast</artifactId>
<version>[3.7,)</version>
</dependency>
<dependency>
<groupId>io.vertx</groupId>
<artifactId>vertx-hazelcast</artifactId>
<version>[3.0.0,)</version>
<exclusions>
<exclusion>
<groupId>com.hazelcast</groupId>
<artifactId>hazelcast</artifactId>
</exclusion>
</exclusions>
</dependency>
然后我删除了旧的启动配置并重新创建它(通过右键单击JUnit测试用例并选择“Debug as Junit”) - 但这并没有改变Eclipse的行为 - 类路径中的一些jar已经移动了一下,但结果仍然是vertx-hazelcast
及其hazelcast-3.6.3.jar
依赖关系在hazelcast-3.8.jar
之前加载。
答案 0 :(得分:0)
注意此答案是与OP讨论的摘要
看起来vertex-hazelcast在hazelcast
上声明了编译和测试范围的依赖关系。这些范围不是传递性的,所以我的理解是这个版本将被设计包含在类路径中。 @Echnalb建议使用排除是recommended解决此问题的方法。
由于这种方法没有奏效,它可能是一个祖先也宣布了一种依赖性,也需要被排除在外。
在查看了vertex-hazelcast
中声明的其他依赖项之后,我检查了hazelcast-client
以查看它是否也声明了对hazelcast
的早期版本的依赖,假设是祖先尽管被排除在父类之外,依赖性仍被添加到类路径中。
它did包含这样的依赖:
<dependency>
<groupId>com.hazelcast</groupId>
<artifactId>hazelcast</artifactId>
<scope>test</scope>
<version>${project.parent.version}</version>
<classifier>tests</classifier>
</dependency>
我建议( ed )为hazelcast-client
添加排除,这似乎解决了这个问题。
@Guss评论
dependency:tree
,hazelcast-client是
根本没有列出dependency:tree
没有检测到测试范围的依赖关系。有没有办法强制它切换范围?