运行mvn依赖关系时,Maven无法识别兄弟模块:树

我正在尝试设置一个多模块Maven项目,并且模块间的依赖关系显然没有正确设置。

我有:

<modules>
  <module>commons</module>
  <module>storage</module>
</modules>

在父POM中(它有一个打包类型的pom),然后是子目录commons/storage/它们定义了JAR poms的同名。

存储取决于Commons。

在主(主)目录中,我运行mvn dependency:tree并查看:

[INFO] Building system
[INFO]    task-segment: [dependency:tree]
[INFO] ------------------------------------------------------------------------
[INFO] [dependency:tree {execution: default-cli}]
[INFO] domain:system:pom:1.0-SNAPSHOT
[INFO] - junit:junit:jar:3.8.1:test
[INFO] ------------------------------------------------------------------------
[INFO] Building commons
[INFO]    task-segment: [dependency:tree]
[INFO] ------------------------------------------------------------------------
[INFO] [dependency:tree {execution: default-cli}]
...correct tree...
[INFO] ------------------------------------------------------------------------
[INFO] Building storage
[INFO]    task-segment: [dependency:tree]
[INFO] ------------------------------------------------------------------------
Downloading: http://my.repo/artifactory/repo/domain/commons/1.0-SNAPSHOT/commons-1.0-SNAPSHOT.jar
[INFO] Unable to find resource 'domain:commons:jar:1.0-SNAPSHOT' in repository my.repo (http://my.repo/artifactory/repo)
[INFO] ------------------------------------------------------------------------
[ERROR] BUILD ERROR
[INFO] ------------------------------------------------------------------------
[INFO] Failed to resolve artifact.

Missing:
----------
1) domain:commons:jar:1.0-SNAPSHOT

为什么对“commons”的依赖失败,即使反应堆显然已经看到它,因为它成功地处理了它的依赖树? 它绝对不应该去'净找到它,因为它在那里...

存储的pom:

<?xml version="1.0" encoding="UTF-8"?>
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <modelVersion>4.0.0</modelVersion>
  <packaging>jar</packaging>
  <parent>
    <artifactId>system</artifactId>
    <groupId>domain</groupId>
    <version>1.0-SNAPSHOT</version>
  </parent>
  <groupId>domain</groupId>
  <artifactId>storage</artifactId>
  <name>storage</name>
  <url>http://maven.apache.org</url>
  <dependencies>
    <!-- module dependencies -->
    <dependency>
      <groupId>domain</groupId>
      <artifactId>commons</artifactId>
      <version>1.0-SNAPSHOT</version>
    </dependency>

    <!-- other dependencies -->
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>
  </dependencies>
</project>

感谢您的任何建议!

(编辑)

为了澄清,我在这里寻找的是这样的:我不想要安装模块X来构建依赖于X的模块Y,因为它们都是从同一个父POM引用的模块。 这对我来说很直观,如果我在同一个源代码树中有两件事情,我不应该安装中间产品来继续构建。 希望我的想法在这里有意义...


我认为问题在于,当你指定一个依赖项时,Maven希望将它作为jar(或其他)打包并且至少可以从本地仓库获得。 我敢肯定,如果你在你的commons项目上运行mvn install ,那么一切都将起作用。


正如在这个Maven邮件列表线程中所讨论的,依赖:树目标本身将在存储库中而不是在反应堆中查找事物。 你可以通过安装mvn来解决这个问题,就像以前的建议一样,或者做一些不太复杂的调用反应堆的东西,比如

mvn compile dependency:tree

适用于我。


意识到这是一个较老的线索,但似乎无论是工具的发展还是这可能都是第一次错过。

可以执行构建,使得依赖关系解决,而无需通过执行反应器构建进行安装。

如果您在描述项目模块结构的父项中开始构建,那么您的模块之间的依赖关系将在构建过程中通过内部Maven反应堆进行解析。

当然,这不是一个完美的解决方案,因为它不能解决结构中单个单独模块的构建问题。 在这种情况下,Maven不会在他的反应堆中拥有依赖关系,并且会寻求在存储库中解决它。 因此,对于个人版本,您仍然必须先安装依赖关系。

这里是描述这种情况的一些参考。

链接地址: http://www.djcxy.com/p/29695.html

上一篇: Maven doesn't recognize sibling modules when running mvn dependency:tree

下一篇: Maven sourcing dependency version from great