1、聚合
Maven的聚合特性能够把项目的各个模块聚合在一起构建,而Maven的继承特性则能帮助抽取各个模块相同的依赖和插件等配置,在简化POM的同时,还能促进各个模块配置的一致性。
2、继承
继承为了解决Maven的重复配置,可以继承的元素如下:
- groupId:项目组ID,项目坐标的核心元素
- version:项目版本,项目坐标的核心元素
- description:项目的描述信息
- organization:项目的组织信息
- inception Year:项目的创始年份
- url:项目的URL地址
- developers:项目的开发者信息
- contributors:项目的贡献者信息
- distributionManagement:项目的部署配置
- issueManagement:项目的缺陷跟踪系统信息
- ciManagement:项目的持续继承系统信息
- rcm:项目的版本控制系统信息
- mailingLists:项目的邮件列表信息
- properties:自定义的Maven属性
- dependencies:项目的依赖配置
- dependencyManagement:项目的依赖管理配置
- repositories:项目的仓库配置
- build:包括项目的源码目录配置、输出目录配置、插件配置、插件管理配置等
- reporting:包括项目的报告输出目录配置、报告插件配置等
3、依赖管理
Maven提供的
dependencyManagement元素既能让子模块继承到父模块的依赖配置,又能保证子模块依赖使用的灵活性。在dependencyManagement元素下的依赖声明不会引入实际的依赖,不过它能够约束dependencies下的依赖使用。
4、插件管理
Maven提供了pluginManagement元素帮助管理插件,该元素中配置的依赖不会造成实际的插件调用行为。当POM中配置了真正的plugin元素,并且其groupId和artifactId与pluginManagement中配置的插件匹配时,pluginManagement的配置才会影响实际的插件行为。
比如多个子模块要生成源码,父插件配置好后,子模块只需配置相应
groupId和artifactId即可,无需每个子模块都需要配置<goal>jar-no-for</goal>等
5、聚合与继承的关系
聚合是为了方便的快速构建项目,继承则是为了消除重复的配置。
6、反应堆
对于单个项目,反应堆就是该模块本身,对于多个模块的项目,反应堆就包含了各个模块之间继承与依赖的关系,从而能够自动计算出合理的模块构建顺序。
<modules>
<module>xxx</module>
<module>xxx</module>
<module>xxx</module>
</modules>