一、分模块设计与开发
分模块设计:
将项目按照功能拆分成若干个子模块,方便项目的管理维护、扩展,也方便模块间的相互调用,资源共享。
注意:分模块开发需要先对模块功能进行设计,再进行编码。不会先将工程开发完毕,然后进行拆分。
二、继承与聚合
1.继承关系
- 继承:描述的是两个工程间的关系,与java中的继承相似,子工程可以继承父工程中的配置信息,常见于依赖关系的继承。
- 作用:简化依赖配置、统一管理依赖
- 实现:<parent>...</parent>
Maven中一些常见的打包方式:
- jar:普通模块打包,springboot项目基本都是jar包(内嵌tomcat运行)
- war:普通web程序打包,需要部署在外部的tomcat服务器中运行
- pom:父工程或聚合工程,该模块不写代码,仅进行依赖管理
2.继承关系的实现
- 创建maven模块tlias-parent,该工程为父工程,设置打包方式pom
- 在子工程的pom.xml文件中,配置继承关系
- 在父工程中配置各个工程共有的依赖(子工程会自动继承父工程的依赖)
注意:
- 在子工程中,配置了继承关系之后,坐标中的groupId是可以省略的,因为会自动继承父工程的;
- relativePath指定父工程的pom文件的相对位置(如果不指定,将从本地仓库/远程仓库查找该工程的);
- 若父子工程都配置了同一个依赖的不同版本,以子工程的为准。
====分模块设计之后,启动程序,仍然可以正常运行====
3.版本锁定
1)父工程统一管理版本号
在maven中,可以在父工程的pom文件中通过<dependencyManagement>来统一管理依赖版本。
子工程引入依赖时,无需指定<version>版本号,父工程统一管理,变更以来版本,只需要在父工程中统一变更。
2)自定义属性/引用属性
在<properties>标签里直接定义版本标签集中管理:
<lombok.version>1.18.20</lombok.version>
<jjwt.version>0.9.0</jjwt.version>
在后面的统一版本管理标签里只需要将<version>标签里面改为:
<version>${jjwt.version}</version>引用属性即可
注意:web开发的起步依赖已经在父工程指定为2.7.5,子工程只用引用即可,无需指定版本。
Q:<dependencyManagement>与<dependency>的区别?
- <dependency>是直接依赖,在父工程配置了依赖,子工程会直接继承下来;
- <dependencyManagement>是统一管理依赖版本,不会直接依赖,还需要在子工程中引入所需依赖(无需指定版本)
4.聚合
聚合:将多个模块组成一个整体,同时进行项目的构建
- 增加<modules>标签,指定需要聚合的模块即可
<module>../tlias-utils<module>
聚合之后就在可以直接在聚合模块tlias-parent继续操作即可,不需要逐一部署每一个模块了。
聚合工程:一个不具有业务功能的”空“工程(有且仅有一个pom文件)===tlias-parent(父工程、聚合工程)
作用:快速构建项目(无需根据依赖关系手动构建,直接在聚合工程上构建即可)
5.总结
- 作用:
- 聚合用于快速构建项目
- 继承用于简化依赖配置,统一管理依赖
- 相同点:
- 聚合与继承的pom.xml文件打包方式均为pom,可以将两种关系制作到同一个pom文件中===tlias-parent(父工程、聚合工程)
- 聚合与继承均属于设计型模块,并无实际的模块内容
- 不同点:
- 聚合是在聚合工程中配置关系,聚合可以感知到参与聚合的模块有哪些
- 继承是在子模块中配置关系,父模块无法感知哪些模块继承了自己
三、私服
1.介绍
私服是一种特殊的远程仓库,它是架设在局域网内的仓库服务,用来代理位于外部的中央仓库,用于解决团队内部的资源共享与资源同步问题。一个项目/公司,只需要一台私服即可,无需自己搭建,会使用即可。
2.资源上传与下载
私服中的三个仓库:
- release:发行的稳定版本
- snapshot:开发阶段
- central:中央仓库
私服配置会使用即可,步骤固定。