1、使用场景
在使用Java开发项目时,一种常见的情形是项目由多个模块组成,软件折及人员往往会采用各种方式对软件划分模块,以得到更清晰de设计以及更高的重用性。Maven的聚合特性能够帮助把项目的各个模块聚合在一起构建。
例如在Maven实战中,许晓斌为我们讲解Maven采用的案例就是一个典型的多模块项目。如下图所示:
当两个模块实现之后,比如说accout-persist和account-email实现之后,一个简单的需求会自然而然的出现:如何一次构建两个项目,而不是到两个模块的目录下分别执行mvn命令。Maven聚合(多模块)的特性就是为这种需求服务的。
2、如何使用
如:A项目下有 a,b,c三个模块
A项目的pom.xml
<modules>
<module>a</module>
<module>b</module>
<module>c</module>
</modules>
上述聚合项目的POM聚合了三个模块:a,b,c三个模块。
我们在使用时,经常回在a,b,c三个项目的pom中增加下面的配置:
<parent>
<artifactId>A</artifactId>
<groupId>com.javxuam.maven</groupId>
<version>1.0-SNAPSHOT</version>
<!--最好声明一下以当前pom文件目录为基准
的父工程的pom文件-->
<relativePath>../pom.xml</relativePath>
</parent>
很多人会因此将maven的聚合和继承混淆,但是需要注意的是a,b,c项目的pom.xml不是必须增加上述配置,Maven聚合的概念主要是方便开发人员对多模块项目的多个模块。
3、聚合的两种形式
1)父子目录结构
<packaging>pom</packaging>
<name>Account Aggregator</name>
<modules>
<module>account-email</module>
<module>account-persist</module>
</modules>
2)平行目录结构
<packaging>pom</packaging>
<name>Account Aggregator</name>
<modules>
<module>../account-email</module>
<module>../account-persist</module>
</modules>
实际上,上述两种目录结构是统一的,这里每个module的值实际都是一个相对于当前POM的相对目录。