多模块Maven项目中的聚合与继承其实是两个概念,其目的完全是不同的。前者主要是为了方便快速构建项目,后者主要是为了消除重复配置。
对于聚合模块来说,他知道有哪些被聚合的模块,但那些被聚合的模块不知道这个聚合模块的存在。
对于继承关系的父POM来说,他不知道有哪些子模块继承于他,但那些子模块都必须知道自己的父POM是什么。
如果非要说两个特性的共同点,那么可以看到,聚合POM与继承关系中的父POM的packaging都必须是pom,同时,聚合模块与继承关系中的父模块除了POM之外都没有实际的内容。
在现有的实际项目中,往往会发现一个POM既是聚合POM,又是父POM,这么做主要是为了方便。一般来说,融合使用聚合与继承也没有什么问题,如下所示。
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.test</groupId>
<artifactId>a</artifactId>
<version>1.0.0-SNAPSHOT</version>
<packaging>pom</packaging>
<name>a</name>
<modules>
<module>b</module>
<module>c</module>
</modules>
<properties>
<springframework.version>2.5.6</springframework.version>
<junit.version>4.7</junit.version>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>${springframework.version}</version>
</dependency>
</dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>${junit.version}</version>
<scope>test</scope>
</dependency>
</dependencyManagement>
<build>
<pluginManagement>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.5</source>
<target>1.5</target>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-resources-plugin</artifactId>
<configuration>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
</plugins>
</pluginManagement>
</build>
</project>
在上面可以看到,该POM的打包方式为pom,他包含了一个modules元素,表示用来聚合b和c两个模块,他还包含了properties、dependencyManagement和pluginManagement元素供子模块继承。
相应的,b和c的POM配置也要做微小的修改。本来a和他们位于同级目录,因此需要使用值为../a/pom.xml的relativePath元素。现在新的a在上一层目录,这是Maven默认能识别的父模块位置,因此不再需要配置relativePath,如下所示。
<parent>
<groupId>com.test</groupId>
<artifactId>a</artifactId>
<version>1.0.0-SNAPSHOT</version>
</parent>
<artifactId>b</artifactId>
<name>b</name>