Maven继承与聚合

1,继承

  • 概念:继承描述的是两个工程间的关系,与java中的继承相似,子工程可以继承父工程中的配置信息,常见于依赖关系的继承。

  • 作用:简化依赖配置、统一管理依赖

  • 实现:

<parent>
    <groupId>...groupId>
    <artifactId>...artifactId>
    <version>...version>
    <relativePath>....relativePath>
parent>

Maven继承与聚合_第1张图片

1.1 继承关系实现

①. 创建maven模块 example-parent ,该工程为父工程,设置打包方式pom(默认jar)。
②. 在子工程的pom.xml文件中,配置继承关系。
③. 在父工程中配置各个工程共有的依赖(子工程会自动继承父工程的依赖)。

父工程:

<parent>
	<groupId>org.springframework.bootgroupId>
	<artifactId>spring-boot-starter-parentartifactId>
	<version>2.7.5version>
	<relativePath/> 
parent>

<groupId>com.examplegroupId>
<artifactId>example-parentartifactId>
<version>1.0-SNAPSHOTversion>
<packaging>pompackaging> 

子工程继承:

<parent>
	<groupId>com.examplegroupId>
	<artifactId>example-parentartifactId>
	<version>1.0-SNAPSHOTversion>
   <relativePath>../ example-parent/pom.xmlrelativePath> 
parent>

jar:普通模块打包,springboot项目基本都是jar包(内嵌tomcat运行)
war:普通web程序打包,需要部署在外部的tomcat服务器中运行
pom:父工程或聚合工程,该模块不写代码,仅进行依赖管理

注意事项:

  1. 在子工程中,配置了继承关系之后,坐标中的groupId是可以省略的,因为会自动继承父工程的 。
  2. relativePath指定父工程的pom文件的相对位置(如果不指定,将从本地仓库/远程仓库查找该工程)。

1.2 版本锁定

在maven中,可以在父工程的pom文件中通过 < dependencyManagement > 来统一管理依赖版本。

父工程:

<dependencyManagement>
	<dependencies>
		
		<dependency>
			<groupId>io.jsonwebtokengroupId>
			<artifactId>jjwtartifactId>
			<version>0.9.1version>
		dependency>
	dependencies>
dependencyManagement>

子工程:

<dependencies>
	
	<dependency>
	<groupId>io.jsonwebtokengroupId>
	<artifactId>jjwtartifactId>
	dependency>
dependencies>

子工程引入依赖时,无需指定 < version> 版本号,父工程统一管理。变更依赖版本,只需在父工程中统一变更。

问题引出:以后我们可能会导入大量的依赖,而这些依赖的版本号会零散的分布在各个坐标中,如果我们需要更改某个依赖的版本号,这时候就比较难找,不方便我们集中和统一管理

解决:使用maven提供的自定义属性/引用属性功能

<properties>
	
	<lombok.version>1.18.24lombok.version>
	<jjwt.version>0.9.0jjwt.version>
properties>

<dependencies>
	<dependency>
		<groupId>org.projectlombokgroupId>
		<artifactId>lombokartifactId>
		<version>${lombok.version}version> 
	dependency>
dependencies>

<dependencyManagement>
	<dependencies>
		
		<dependency>
			<groupId>io.jsonwebtokengroupId>
			<artifactId>jjwtartifactId>
			<version>${jjwt.version}version>
		dependency>
	dependencies>
dependencyManagement>

< dependencyManagement> 与 < dependencies>的区别是什么?

  1. < dependencies> 是直接依赖,在父工程配置了依赖,子工程会直接继承下来。
  2. < dependencyManagement> 是统一管理依赖版本,不会直接依赖,还需要在子工程中引入所需依赖(无需指定版本)

2,聚合

  • 概念:将多个模块组织成一个整体,同时进行项目的构建。
  • 聚合工程:一个不具有业务功能的“空”工程(有且仅有一个pom文件)
  • 作用: 快速构建项目(无需根据依赖关系手动构建,直接在聚合工程上构建即可)

Maven继承与聚合_第2张图片

实现:maven中可以通过 < modules> 设置当前聚合工程所包含的子模块名称

父工程(聚合工程):


<modules>
	<module>../example-pojomodule>
	<module>../example-utilsmodule>
	<module>../example-web-managementmodule>
modules>

聚合工程中所包含的模块,在构建时,会自动根据模块间的依赖关系设置构建顺序,与聚合工程中模块的配置书写位置无关。

继承与聚合:

  • 作用
    • 聚合用于快速构建项目
    • 继承用于简化依赖配置、统一管理依赖
  • 相同点:
    • 聚合与继承的pom.xml文件打包方式均为pom,可以将两种关系制作到同一个pom文件中
    • 聚合与继承均属于设计型模块,并无实际的模块内容
  • 不同点:
    • 聚合是在聚合工程中配置关系,聚合可以感知到参与聚合的模块有哪些
    • 继承是在子模块中配置关系,父模块无法感知哪些子模块继承了自己

你可能感兴趣的:(Java,maven,java,spring,boot)