mvn package -pl ${PACKAGE} -am ,连锁依赖不build的原因

背景资料:

项目结构为:xxx-parent(父pom),xxx-client(子pom,jar包),xxx-web(子pom,war包,依赖xxx-client)

我们的maven项目打包时,在根目录下,使用

mvn clean -U package -pl xxx-web -am -P $PROFILE  -Dmaven.test.skip=$SKIP_TEST

进行打包。基于资料可知,此时应该将xxx-web包,及其依赖的module(xxx-client)一起进行build。(资料:按需构建多模块,玩转Maven反应堆maven guide: multiple modulesmaven cli references

但是实际使用时,xxx-client没有被build,导致无法在打包的同时,进行client包的编译(主要目的是进行代码检查、client文档上传)。

几经尝试后,发现是pom.xml中的version设置问题。

在项目中出于方(偷)便(懒)考虑,父pom的dependencyManagement的版本限制,和子pom的version定义,都使用了变量定义在父pom里。如下。

父pom:
<properties>
    <project-parent.version>1.0-SNAPSHOT</project-parent.version>
    <project-client.version>1.2</project-client.version>
    <project-web.version>1.0-SNAPSHOT</project-web.version>
</properties>
子pom:
<parent>
    <groupId>com.abc.ddd</groupId>
    <artifactId>xxx</artifactId>
    <version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>xxx-client</artifactId>
<version>${project-client.version}</version>
<packaging>jar</packaging>
<name>${project.artifactId}</name>
<url>http://maven.apache.org</url>

pom 使用变量作为自身的version声明 一直不被maven团队支持,编译时会高亮WARNING提示。此次使用-pl -am,却没有按预期进行依赖编译,算是忽视它的代价。

将version独立声明后,再次打包,能够顺利触发xxx-client的编译,问题得到解决。如下。

子pom改:
<parent>
    <groupId>com.abc.ddd</groupId>
    <artifactId>xxx</artifactId>
    <version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>xxx-client</artifactId>
<version>1.2</version>
<packaging>jar</packaging>
<name>${project.artifactId}</name>
<url>http://maven.apache.org</url>
发布了66 篇原创文章 · 获赞 17 · 访问量 10万+

猜你喜欢

转载自blog.csdn.net/ligeforrent/article/details/83417840