7

我正在使用 Maven 3 构建一个具有 3 层的 Java 应用程序 - 服务器、ejb 和 ui。EJB 项目依赖于Server 项目,UI 项目只依赖EJB,并为Server 传递依赖提供了排除。

当 UI 项目构建为战争时,尽管它没有显示在 dependency:tree 命令中,但仍包含服务器依赖项。

这是运行的相关输出mvn dependency:tree

**project.name:UI:war:1.0 SNAPSHOT**
+-  project.name:Common:jar:1.0 SNAPSHOT:compile
|   +  org_common:_lib:jar:16.0.006:compile
|   |  +- log4j:log4j:jar:1.2.16:compile
|   |  \- commons configuration:commons configuration:jar:1.6:compile
|   |     +- commons lang:commons lang:jar:2.4:compile
|   |     +- commons digester:commons digester:jar:1.8:compile
|   |     \- commons beanutils:commons beanutils core:jar:1.8.0:compile
|   +- org_common:_security_lib:jar:16.0.006:compile
|   \- org.springframework:spring:jar:2.0:compile
+-  **project.name:EJB:ejb client:client:1.0 SNAPSHOT:compile**
|   \- com.ibm.websphere.appserver:j2ee:jar:7.0.0.9:compile
+-  org_common:_uicomponent:jar:16.0.006:compile

这是运行时的输出依赖树mvn clean install -X

**project.name:UI:war:1.0 SNAPSHOT**
+-  project.name:Common:jar:1.0 SNAPSHOT:compile
|   +  org_common:_lib:jar:16.0.006:compile
|   |  +- log4j:log4j:jar:1.2.16:compile
|   |  \- commons configuration:commons configuration:jar:1.6:compile
|   |     +- commons lang:commons lang:jar:2.4:compile
|   |     +- commons digester:commons digester:jar:1.8:compile
|   |     \- commons beanutils:commons beanutils core:jar:1.8.0:compile
|   +- org_common:_security_lib:jar:16.0.006:compile
|   \- org.springframework:spring:jar:2.0:compile
+-  **project.name:EJB:ejb client:client:1.0 SNAPSHOT:compile**
|   +- **project.name:Server:jar:1.0 SNAPSHOT:compile**
|   |   +- javassist:javassist:jar:3.4.GA:compile
|   |   +- project.filestore:filestore_client:jar:7.0.003:compile
|   |   +- com.ibm.db2:db2jcc:jar:9.7.fp1.aix64.s091114:compile
|   |   +- com.ibm.db2:db2java:jar:9.7.fp1.aix64.s091114:compile
|   |   +- com.ibm.db2:db2jcc_license_cu:jar:9.7.fp1.aix64.s091114:compile
|   \- com.ibm.websphere.appserver:j2ee:jar:7.0.0.9:compile
+-  org_common:_uicomponent:jar:16.0.006:compile

对 Server 的依赖是两棵树之间的唯一区别。这两个输出不应该总是相同的吗?什么可能导致包含未显示在依赖项中的库:树?

父 POM 将模块定义为:

<modules>
    <module>Server</module>
    <module>EJB</module>
    <module>UI</module>
</modules>

EJB POM 中列出的依赖项是:

<dependencies>
        <dependency>
            <groupId>project.name</groupId>
            <artifactId>Server</artifactId>
            <version>${project.version}</version>
        </dependency>
    </dependencies>

UI中的依赖是:

<dependencies>
        <dependency>
            <groupId>project.name</groupId>
            <artifactId>EJB</artifactId>
            <version>${project.version}</version>
            <type>ejb-client</type>
            <exclusions>
                <exclusion>
                    <groupId>project.name</groupId>
                    <artifactId>Server</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
</dependencies>

我知道我可以明确地将服务器 jar 排除在 WAR 中,但我更愿意解决实际问题。

4

2 回答 2

5

你是对的,两种情况下的输出应该是相同的。然而,Maven 3 转而使用 Aether 进行依赖解析,但截至目前,dependency:tree 使用旧的依赖解析机制,这就是差异的原因。详情请查看以下链接。

https://cwiki.apache.org/MAVEN/maven-3x-compatibility-notes.html#Maven3.xCompatibilityNotes-DependencyResolution

由于这个原因,您应该只依赖 mvn clean install -X 的输出来进行依赖管理。

编辑

由于 Maven 依赖插件的 2.5 版,dependency:tree也使用 Aether(请参阅错误报告发行说明

于 2012-04-10T02:19:15.333 回答
1

正如我们在评论中发现的那样,问题的根源是有缺陷的 Maven 3.0.3。3.0.4 版解决了这个问题。

我在那里的评论:

您使用哪个确切的 Maven 版本?如果不是 3.0.4,试试看它是否有帮助。在使用以前的 Maven 3 版本(主要是 3.0.2)时,我发现了非常非常糟糕的问题。

于 2012-04-11T07:45:33.880 回答