Maven的聚合(多模块)和Parent继承
即使是长期从事 Maven 工作的开发人员也不能完全掌握聚合(多模块)和 Parent 继承的关系,在使用多模块时,子模块总要指定聚合的 pom 为 <parent>
。由于在大多数示例中都是这么写的,所以很难让人搞懂这两者的具体作用和关系。
实际上在 Maven 中聚合(多模块)和继承是两回事,两者不存在直接联系。
pom文档地址:https://maven.apache.org/pom.html
Maven 完全参考:http://books.sonatype.com/mvnref-book/reference/index.html
继承
继承是 Maven 中很强大的一种功能,继承可以使得子POM可以获得 parent 中的各项配置,可以对子pom进行统一的配置和依赖管理。父POM中的大多数元素都能被子POM继承,这些元素包含:
- groupId
- version
- description
- url
- inceptionYear
- organization
- licenses
- developers
- contributors
- mailingLists
- scm
- issueManagement
- ciManagement
- properties
- dependencyManagement
- dependencies
- repositories
- pluginRepositories
- build
- plugin executions with matching ids
- plugin configuration
- etc.
- reporting
- profiles
注意下面的元素,这些都是不能被继承的。
- artifactId
- name
- prerequisites
想要添加 parent,只需要像下面这样写。
<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 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.codehaus.mojo</groupId> <artifactId>my-parent</artifactId> <version>2.0</version> <relativePath>../my-parent</relativePath> </parent> <artifactId>my-project</artifactId> </project>
其中relativePath
元素不是必须的,指定后会优先从指定的位置查找父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 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>org.codehaus.mojo</groupId> <artifactId>my-parent</artifactId> <version>2.0</version> <packaging>pom</packaging> <modules> <module>my-project</module> <module>another-project</module> </modules> </project>
在列出模块时,不需要自己考虑模块间依赖关系,即POM给出的模块排序并不重要。Maven将对模块进行拓扑排序,使得依赖关系始终在依赖模块之前构建。
聚合 VS 父POM
虽然聚合通常伴随着父POM的继承关系,但是这两者不是必须同时存在的,从上面两者的介绍可以看出来,这两者的都有不同的作用,他们的作用不依赖于另一个的配置。
父POM是为了抽取统一的配置信息和依赖版本控制,方便子POM直接引用,简化子POM的配置。聚合(多模块)则是为了方便一组项目进行统一的操作而作为一个大的整体,所以要真正根据这两者不同的作用来使用,不必为了聚合而继承同一个父POM,也不比为了继承父POM而设计成多模块。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接
您可能感兴趣的文章:
- Maven之Parent模块配置-关于聚合与继承、依赖管理、占位符、构建管理和多套环境
- Maven 的聚合(多模块)和 Parent 继承
- Eclipse下Maven工程多模块继承和聚合创建
- 为方便管理Maven中的模块,Maven提供了聚合与继承来管理
- Eclipse下Maven工程多模块继承和聚合的创建
- Maven模块聚合与继承
- maven 为何要模块划分-聚合/继承
- Maven聚合模块与继承和Maven的生命周期
- Maven模块聚合与继承
- Maven工程多模块继承和聚合项目创建与数据库测试步骤详解
- Maven 聚合(modules标签)与继承(parent标签)的笔记
- Maven系列五:多模块项目中的聚合和继承
- Maven聚合模块与继承和Maven的生命周期
- maven的聚合模块和pom继承使用(六)
- maven 为何要模块划分-聚合/继承
- maven-Maven的聚合模块和pom的继承使用
- maven的聚合模块和pom继承使用
- Maven聚合模块与继承和Maven的生命周期
- Eclipse下Maven工程多模块继承和聚合创建(详解)
- maven的聚合模块和pom继承使用(六)