分模块设计与开发
分模块设计:将项目按照功能拆分为若干个模块,方便项目的管理维护、扩展,也方便模块间的相互调用,资源共享
分模块开发:
- 创建maven模块pojo,存放实体类
- 创建maven模块utils,存放相关工具类
注意事项:分模块开发需要先针对模块功能进行设计,再进行编码,不会先将工程开发完毕,然后进行拆分
继承与聚合
继承
概念:继承描述的是两个工程间的关系,与java中的继承相似,子工程可以继承父工程中的配置信息,常见于依赖关系的继承
作用:简化依赖配置、统一管理依赖
实现:parent标签
继承关系实现
-
创建maven模块parent,该工程为父工程,设置打包方式pom(默认jar)
-
在子工程的pom.xml文件中,配置继承关系
-
在父工程中配置各个工程共有的依赖(子工程会自动继承父工程的依赖)
只能单继承,不能多继承,但可以多重继承
注意事项:
- 在子工程中,配置了继承关系之后,坐标中的groupId是可以省略的,因为会自动继承父工程的
- relativePath指定父工程的pom文件的相对位置(如果不指定,将从本地仓库/远程仓库查找该工程)
- 若父子工程都配置了同一个依赖的不同版本,以子工程为准
三种打包方式
- jar:普通模块打包,springboot项目基本都是jar包(内嵌tomcat运行)
- war:普通web程序打包,需要部署在外部的tomcat服务器中运行
- pom:父工程或聚合工程,该模块不写代码,仅进行依赖管理
版本锁定
在maven中,可以在父工程的pom文件中通过dependencyManagement标签来统一管理各个依赖的版本
注意事项:子工程引入依赖时,无需指定version版本号,父工程统一管理,变更依赖版本,只需在父工程中统一变更
自定义属性/引用属性
dependencyManagement与dependencies的区别是什么(面试题)
- dependencies是直接依赖,在父工程配置了依赖,子工程会直接继承下来
- dependencyManagement是统一管理依赖版本,不会直接依赖,还需要在子工程中引入所需依赖(无需指定版本)
聚合
聚合:将多个模块组织成一个整体,同时进行项目的创建
聚合工程:一个不具有业务功能"空"工程(有且仅有一个pom文件)
作用:快速构建项目(无需根据依赖关系手动构建,直接在聚合工程上构建即可)
实现:maven中可以通过modules设置当前聚合工程所包含的子模块名称
注意事项:聚合工程中所包含的模块,在构建时,会自动根据模块间的依赖关系设置构建顺序,与聚合工程中模块的配置书写位置无关
继承与聚合总结
作用:
- 聚合用于快速构建项目
- 继承用于简化依赖配置、统一管理依赖
相同点:
- 聚合与继承的pom.xml文件打包方式均为pom,可以将两种关系制作到同一个pom文件中
- 聚合与继承均属于设计型模块,并无实际的模块内容
不同点:
- 聚合是在聚合工程中配置关系,聚合可以感知到参与聚合的模块有哪些
- 继承是在子模块中配置关系,父模块无法感知哪些子模块继承了自己
私服
私服是一种特殊的远程仓库,它是架设在局域网内的仓库服务,用来代理位于外部的中央仓库,用于解决团队内部的资源共享与资源同步问题
依赖查找顺序:本地仓库->私服->中央仓库
注意事项:私服在企业项目开发中,一个项目/公司,只需要一台即可(无需我们自己搭建,会使用即可)
资源上传与下载
项目版本
- release(发行版本):功能趋于稳定、当前更新停止,可以用于发行的版本,存储在私服中的release仓库中
- snapshot(快照版本):功能不稳定、尚处于开发中的版本,即快照版本,存储在私服的snapshot仓库中