- her~~llo,我是你们的好朋友Lyle,是名梦想成为计算机大佬的男人!
博客是为了记录自我的学习历程,加强记忆方便复习,如有不足之处还望多多包涵!非常欢迎大家的批评指正。
今天我们进入新的学习环节——Maven进阶学习。
目录
一、学习目标
- 理解分模块开发的意义
- 能够使用聚合工程快速构建项目
- 能够使用继承简化项目配置
- 能够根据需求配置生产、开发、测试环境,并在各环境间切换运行
二、分模块开发
2.1 分模块开发意义:
将原始模块按照功能拆分成若干个子模块,方便模块间的相互调用,接口共享.
2.2 分模块开发与设计:
①创建Maven模块
②书写模块代码
③通过maven指令安装模块到本地仓库( install指令)
(团队内部开发需要发布模块功能到团队内部可共享的仓库中(私服))
注意:
- 分模块开发需要先针对模块功能进行设计,再进行编码。不会先将工程开发完毕,然后进行拆分。
三、依赖管理
依赖指当前项目运行所需的jar,一个项目可以设置多个依赖。
3.1 依赖传递
依赖具有传递性。
- 直接依赖:在当前项目中通过依赖配置建立的依赖关系。
- 间接依赖:被资源的资源如果依赖其他资源,当前项目间接依赖其他资源。
依赖传递冲突问题
路径优先:当依赖中出现相同的资源时,层级越深,优先级越低,层级越浅,优先级越高
声明优先:当资源在相同层级被依赖时,配置顺序靠前的覆盖配置顺序靠后的
特殊优先:当同级配置了相同资源的不同版本,后配置的覆盖先配置的
3.2 可选依赖
可选依赖指对外隐藏当前所依赖的资源——不透明
<dependency> <groupId>org.example</groupId> <artifactId>Maven_03_pojo</artifactId> <version>1.0-SNAPSHOT</version> <!--可选依赖是隐藏当前工程所依赖的资源,隐藏后对应的资源将不具有依赖传递性--> <optional>true</optional> </dependency>
3.3 排除依赖
排除依赖指主动断开依赖的资源,被排除的资源无需指定版本——不需要
<dependency> <groupId>org.example</groupId> <artifactId>Maven_04_dao</artifactId> <version>1.0-SNAPSHOT</version> <!-- 排除依赖是隐藏当前资源对应的依赖关系--> <exclusions> <exclusion> <groupId>log4j</groupId> <artifactId>log4j</artifactId> </exclusion> </exclusions> </dependency>
排除依赖资源仅指定groupId和artifactId即可,无需指定version
四、聚合与继承
4.1 聚合
聚合:将多个模块组织成一个整体,同时进行项目构建的过程称为聚合。
聚合工程:通常是一个不具有业务功能的“空”工程(有且仅有一个pom文件)。
作用:使用聚合工程可以将多个工程编组,通过对聚合工程进行构建,实现对所包含的模块进行同步构建。
当工程中某个模块发生更新(变更)时,必须保障工程中与已更新模块关联的模块同步更新,此时可以使用聚合工程来解决批量模块同步构建的问题。聚合工程开发:
①创建Maven模块,设置打包类型为pom
<packaging>pom</packaging>
注意:
- 每个maven工程都有对应的打包方式,默认为jar ,web工程打包方式为war。
②设置当前聚合工程所包含的子模块名称
<!--设置管理模块的名称--> <modules> <module>../Maven_02_ssm</module> <module>../Maven_03_pojo</module> <module>../Maven_04_dao</module> </modules>
注意:
- 聚合工程中所包含的模块在进行构建时会根据模块间的依赖关系设置构建顺序,与聚合工程中模块的配置书写位置无关;
- 参与聚合的工程无法向上感知是否参与聚合,只能向下配置哪些模块参与本工程的聚合。
4.2 继承
继承描述的是两个工程间的关系,与java中的继承相似,子工程可以继承父工程中的配置信息,常见于依赖关系的继承。
作用:
- 简化配置
- 减少版本冲突
开发:
①创建Maven模块,设置打包类型为pom
<packaging>pom</packaging>
注意:
- 建议父工程打包方式设置为pom
②在父工程的pom文件中配置依赖关系(子工程将沿用父工程中的依赖关系)
<dependencies> <dependency> <groupId>...</groupId> <artifactId>...</artifactId> <version>...</version> </dependency> ... </dependencies>
③在父工程的pom文件中配置子工程中可选依赖的坐标
<!--定义依赖管理--> <dependencyManagement> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.13.2</version> <scope>test</scope> </dependency> </dependencies> </dependencyManagement>
④在子工程中配置当前工程所继承的父工程
<!--配置当前工程继承自parant工程--> <parent> <groupId>org.example</groupId> <artifactId>Maven_01_parent</artifactId> <version>1.0-SNAPSHOT</version> <!--填写父工程的pom文件--> <relativePath>../Maven_01_parent/pom.xml</relativePath> </parent>
⑤在子工程中配置使用父工程中可选依赖的坐标
<dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <scope>test</scope> </dependency>
注意:
- 子工程中使用父工程中的可选依赖时,仅需要提供groupId和artifactId,无需提供版本,版本由父工程统一提供,避免版本冲突
- 子工程中还可以定义父工程中没有定义的依赖关系
4.3 聚合与继承的区别
作用:
- 聚合用于快速构建项目
- 继承用于快速配置
相同点:
- 聚合与继承的pom.xml文件打包方式均为pom,可以将两种关系制作到同一个pom文件
- 聚合与继承均属于设计型模块,并无实际的模块内容
不同点:
- 聚合是在当前模块中配置关系,聚合可以感知到参与聚合的模块有哪些
- 继承是在子模块中配置关系,父模块无法感知哪些子模块继承了自己
五、属性
类似Java定义变量。可以方便版本控制,一改全改。
5.1 pom里属性的配置与使用:
①定义属性
<!-- 定义自定义属性--> <properties> <spring.version>5.3.20</spring.version> </properties>
②引用属性
<dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${spring.version}</version> </dependency>
5.2 资源文件引用属性
①定义属性
<!-- 定义自定义属性--> <properties> <spring.version>5.3.20</spring.version> <jdbc.url>jdbc:mysql://localhost:3306/brand?useSSL=false</jdbc.url> </properties>
②配置文件中引用属性
jdbc.driver=com.mysql.cj.jdbc.Driver jdbc.url=${jdbc.url} jdbc.username=root jdbc.password=123456
③开启资源文件目录加载属性的过滤器
<build> <resources> <resource> <directory>${project.basedir}/src/main/resources</directory> <filtering>true</filtering> </resource> </resources> </build>
④配置maven打war包时,忽略web.xml检查(了解)
<build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-war-plugin</artifactId> <version>3.2.3</version> <configuration> <failOnMissingWebXml>false</failOnMissingWebXml> </configuration> </plugin> </plugins> </build>
5.3 其他属性(了解)
属性列表:
属性分类 引用格式 示例 自定义属性 ${自定义属性名} ${spring.version} 内置属性 ${内置属性名} ${basedir} ${version} Setting属性 ${setting.属性名} ${settings.localRepository} Java系统属性 ${系统属性分类.系统属性名} ${user.home} 环境变量属性 ${env .环境变量属性名} ${env .JAVA_HOME}
通过cmd,在maven的bin下输入mvn help:system可以获取这些属性列表详情。5.4 版本管理
工程版本:
- SNAPSHOT(快照版本)
- 项目开发过程中临时输出的版本,称为快照版本
- 快照版本会随着开发的进展不断更新
- RELEASE(发布版本)
- 项目开发到进入阶段里程碑后,向团队外部发布较为稳定的版本,这种版本所对应的构件文件是稳定的,即便进行功能的后续开发,也不会改变当前发布版本内容,这种版本称为发布版本
发布版本:
- alpha版
- beta版
- 纯数字版
六、多环境配置与应用
6.1 多环境开发:
maven提供配置多种环境的设定,帮助开发者使用过程中快速切换环境。
①定义多环境
<!--配置多环境--> <profiles> <!--开发环境--> <profile> <id>env_dep</id> <properties> <jdbc.url>jdbc:mysql://ip:3306/brand?useSSL=false</jdbc.url> </properties> <!--设定是否为默认启动的环境--> <activation> <activeByDefault>true</activeByDefault> </activation> </profile> <!--生产环境--> <profile> <id>env_pro</id> <properties> <jdbc.url>jdbc:mysql://ip:3306/brand?useSSL=false</jdbc.url> </properties> </profile> <!--测试环境--> <profile> <id>env_test</id> <properties> <jdbc.url>jdbc:mysql://ip:3306/brand?useSSL=false</jdbc.url> </properties> </profile> </profiles>
②:使用多环境(构建过程)
mvn 指令 -P 环境定义id
范例:
mvn install -P env_pro
6.2 跳过测试(了解)
应用场景:
- 功能更新中并且没有开发完毕
- 快速打包
- ...
方式一(指令):
mvn 指令 -D skipTests
范例:
mvn install -D skipTests
注意:
- 执行的项目构建指令必须包含测试生命周期,否则无效果。例如执行compile生命周期,不经过test生命周期
方式二(细粒度控制跳过测试):
<build> <plugins> <plugin> <artifactId>maven-surefire-plugin</artifactId> <version>2.12.4</version> <configuration> <!--是否跳过测试,true直接跳过,false可以添加排除掉不参与测试的内容--> <skipTests>false</skipTests> <!--包含指定的测试--> <includes> <include>**/User*Test.java</include> </includes> <!--排除掉不参与测试的内容--> <excludes> <exclude>**/BookServiceTest.java</exclude> </excludes> </configuration> </plugin> </plugins> </build>
方式三(IDEA功能键):
七、私服
7.1 私服简介
私服是一台独立的服务器,用于解决团队内部的资源共享与资源同步问题。
Nexus:
Sonatype公司的一款maven私服产品
下载地址:
Download
https://help.sonatype.com/repomanager3/product-information/download
启动服务器(命令行启动)
nexus.exe /run nexus
访问服务器(默认端口:8081)
- http://localhost: 8081
修改基础配置信息
- 安装路径下etc目录中nexus-default.properties文件保存有nexus基础配置信息,例如默认访问端口
修改服务器运行配置信息
- 安装路径下bin目录中nexus .vmoptions文件保存有nexus服务器启动对应的配置信息,例如默认占用内存空间
7.2 私服资源操作流程分析
私服里有多个仓库,多个仓库组成一个仓库组,获取资源时直接访问,直接返回出资源,开发人员不用关注资源在哪个仓库。私服可以从中央仓库,获得第三方资源,开发时只通过私服获取就可。
7.3 私服仓库分类
仓库类别 英文名称 功能 关联操作 宿主仓库 hosted 保存自主研发+第三方资源 上传 代理仓库 proxy 代理连接中央仓库 下载 仓库组 group 为仓库编组简化下载操作 下载 7.4 资源上传与下载
我在私服中添加Release和Snapshot两个新的仓库,然后在maven-public这个仓库添加新建的两个子仓库。
资源上传
①本地仓库访问私服地址设置
配置位置( setting.xml文件中)
<mirrors></mirrors>中
<!-- 私服的仓库组访问路径--> <mirror> <id>maven-public</id> <url>http://localhost:8081/repository/maven-public/</url> <mirrorOf>*</mirrorOf> </mirror>
②本地仓库访问私服权限设置
配置位置( setting.xml文件中)
<servers></servers>中
<!--配置访问私服的权限--> <server> <id>Release</id> <username>admin</username> <password>123456</password> </server> <server> <id>Snapshot</id> <username>admin</username> <password>123456</password> </server>
③工程上传到私服服务器设置
配置位置(工程pom文件中)
<!--配置当前工程保存在私服中的具体位置--> <distributionManagement> <repository> <id>Release</id> <url>http://localhost:8081/repository/Release/</url> </repository> <snapshotRepository> <id>Snapshot</id> <url>http://localhost:8081/repository/Snapshot/</url> </snapshotRepository> </distributionManagement>
发布命令
mvn deploy
私服访问中央服务器设置
配置位置( nexus服务器页面设置)
结语:
Maven进阶学习到此结束,我是Lyle,我们下次开始学习Spring Boot 框架。