阶段四:热门框架(第四章:Maven高级)
Maven高级
代码maven_01_parent
、maven_02_ssm
、maven_03_pojo
、maven_04_dao
学习目标
- 理解分模块开发的意义
- 能够使用聚合工程快速构建项目
- 能够使用继承简化项目配置
- 能够根据需求配置生产、开发、测试环境,并在各环境间切换运行
解决不能提交的本地仓库的问题
https://blog.csdn.net/li15974168626/article/details/109576910
一、分模块开发与设计
1、分模块开发的意义
问题导入
分模块开发对工程有什么好处?
模块拆分原则
目的:项目的扩展性变强了,方便其他项目引用相同的功能。
- 将原始模块按照功能拆分成若干个子模块,方便模块间的相互调用,接口共享
2、分模块开发与设计(模块拆分)
问题导入
一个完整的工程依据什么来进行模块的拆分?
提前已经创建springboot工程了
2.1、创建Maven模块
2.2、书写模块代码
注意事项:
- 分模块开发需要先针对模块功能进行设计,再进行编码。不会先将工程开发完毕,然后进行拆分
2.3、通过maven指令安装模块到本地仓库(install指令)
mvn install
或者在该模块的Maven
中通过双击install
命令来进行安装:
注意事项:
- 团队内部开发需要发布模块功能到团队内部可共享的仓库中(私服)
最后在最终开发的项目
里添加依赖
来引用一下提取的模块的坐标
,如下:
最后要注意的是,可能我们所写的模块可能也要依赖一些其他的坐标,比如我们写dao
模块的时候就要添加mybatis
的依赖和mysql
的依赖;
二、依赖管理
- 依赖管理指当前项目运行所需的jar,一个项目可以设置多个依赖
- 格式:
<!--设置当前项目所依赖的所有jar-->
<dependencies>
<!--设置具体的依赖-->
<dependency>
<!--依赖所属群组id-->
<groupId>org.springframework</groupId>
<!--依赖所属项目id-->
<artifactId>spring-webmvc</artifactId>
<!--依赖版本号-->
<version>5.2.10.RELEASE</version>
</dependency>
</dependencies>
1、依赖传递
问题导入
A依赖B,B依赖C,A是否依赖于C呢?
- 依赖具有传递性
- 直接依赖:在当前项目中通过依赖配置建立的依赖关系
- 间接依赖:被资源的资源如果依赖其他资源,当前项目间接依赖其他资源
- 特殊优先:当同级配置了相同资源的不同版本,后配置的覆盖先配置的
2、可选依赖
问题导入
A依赖B,B依赖C,如果A不想将C依赖进来,是否可以做到?
- 可选依赖 指对外隐藏当前所依赖的资源————不透明
如:
<optional>false</optional>
<dependency>
<groupId>com.itheima</groupId>
<artifactId>maven_03_pojo</artifactId>
<version>1.0-SNAPSHOT</version>
<!--可选依赖是隐藏当前工程所依赖的资源,隐藏后对应资源将不具有依赖传递性-->
<optional>false</optional><!--true代表不透明,false代表透明;-->
</dependency>
表示:虽然我依赖了maven_03_pojo
,但是当别人依赖我的时候,我不想让他知道我依赖了maven_03_pojo
,此时别人也无法间接依赖到maven_03_pojo
3、排除依赖
问题导入
A依赖B,B依赖C,如果A不想将C依赖进来,是否可以做到?
- 排除依赖 指主动断开依赖的资源,被排除的资源无需指定版本————不需要
- 排除依赖资源仅指定GA即可,无需指定V;
<dependency>
<groupId>com.itheima</groupId>
<artifactId>maven_04_dao</artifactId>
<version>1.0-SNAPSHOT</version>
<!--排除依赖是隐藏当前资源对应的依赖关系-->
<exclusions>
<exclusion>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
</exclusion>
<exclusion>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
</exclusion>
</exclusions>
</dependency>
表示:虽然我引用了maven_04_dao
,我需要依赖你,但是maven_04_dao
你所依赖的log4j
和mybatis
我不想要,将之排除;
4、可选依赖和排除依赖的区别
三、聚合与继承【在以后的头条项目中有用到】
1、聚合工程
问题导入
什么叫聚合?
-
聚合:将多个模块组织成一个整体,同时进行项目构建的过程称为聚合
-
聚合工程:通常是一个不具有业务功能的”空“工程(有且仅有一个pom文件)
-
作用:使用聚合工程可以将多个工程编组,通过对聚合工程进行构建,实现对所包含的模块进行同步构建
- 当工程中某个模块发生更新(变更)时,必须保障工程中与已更新模块关联的模块同步更新,此时可以使用聚合工程来解决批量模块同步构建的问题
- 当工程中某个模块发生更新(变更)时,必须保障工程中与已更新模块关联的模块同步更新,此时可以使用聚合工程来解决批量模块同步构建的问题
2、聚合工程开发
问题导入
工程的打包方式有哪几种?
web
工程打包方式为<packaging>war</packaging>
聚合工程
打包方式为<packaging>pom</packaging>
其他如果不写打包方式,就是默认为jar
包,比如我们的项目所分离出去的那些新建的依赖,都是jar
包,以供工程依赖使用
2.1、创建Maven模块,设置打包类型为pom
创建一个聚合工程模块,打包方式为pom
<packaging>pom</packaging>
注意事项:
- 每个maven工程都有对应的打包方式,默认为jar,web工程打包方式为war
2.2、设置当前聚合工程所包含的子模块名称
通过相对路径来设置
<!--设置管理的模块名称-->
<modules>
<module>../maven_ssm</module>
<module>../maven_pojo</module>
<module>../maven_dao</module>
</modules>
注意事项:
- 聚合工程中所包含的模块在进行构建时会根据模块间的依赖关系设置构建顺序,与聚合工程中模块的配置书写位置无关。
- 参与聚合的工程无法向上感知是否参与聚合,只能向下配置哪些模块参与本工程的聚合。
到此,我们调试聚合工程,发现它的那些子模块也被调试跑通了
3、继承关系
问题导入
什么叫继承?
- 概念:
- 继承描述的是两个工程间的关系,与java中的继承相似,子工程可以继承父工程中的配置信息,常见于依赖关系的继承
- 作用:
- 简化配置
- 减少版本冲突
4、继承关系开发
4.1、创建Maven模块,设置打包类型为pom
<packaging>pom</packaging>
这一步与2.1
是一样的;
注意事项:
- 建议父工程打包方式设置为pom
4.2、在父工程的pom文件中配置依赖关系(子工程将沿用父工程中的依赖关系)
下面的依赖关系是子工程都可以继承到的依赖
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.2.10.RELEASE</version>
</dependency>
……
</dependencies>
4.3、配置子工程中可选的依赖关系
下面的这些依赖是子工程中可以自由选择是否要继承的依赖
<!--定义子类可选择的依赖管理-->
<dependencyManagement>
<dependencies>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.16</version>
</dependency>
……
</dependencies>
</dependencyManagement>
4.4、在子工程中配置当前工程所继承的父工程
下面代码不表示,子工程要继承那个父工程
<!--定义该工程的父工程-->
<parent>
<groupId>com.itheima</groupId>
<artifactId>maven_parent</artifactId>
<version>1.0-SNAPSHOT</version>
<!--填写父工程的pom文件,根据实际情况填写-->
<relativePath>../maven_parent/pom.xml</relativePath>
</parent>
4.5、在子工程中配置使用父工程中可选依赖的坐标
表示子工程中要继承的父工程的那个可选依赖;
<dependencies>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
</dependency>
</dependencies>
注意事项:
- 子工程中使用父工程中的可选依赖时,仅需要提供群组id和项目id,无需提供版本,版本由父工程统一提供,避免版本冲突
- 子工程中还可以定义父工程中没有定义的依赖关系
5、聚合与继承的区别
问题导入
聚合和继承的作用?
- 作用:
- 聚合用于快速构建项目
- 继承用于快速配置
- 相同点:
- 聚合与继承的
pom.xml
文件打包方式均为pom
,可以将两种关系制作到同一个pom文件中 - 聚合与继承均属于设计型模块,并无实际的模块内容
- 聚合与继承的
- 不同点:
- 聚合是在当前父模块中配置关系,聚合可以感知到参与聚合的模块有哪些
- 继承是在子模块中配置关系,父模块无法感知哪些子模块继承了自己
四、属性管理
1、属性
问题导入
定义属性有什么好处?
1.1、属性配置与使用【重要】【头条项目中使用到】
①:定义属性
如下定义了三条属性,他们的版本如下面所示:
<!--定义自定义属性-->
<properties>
<spring.version>5.2.10.RELEASE</spring.version>
<junit.version>4.12</junit.version>
<mybatis-spring.version>1.3.0</mybatis-spring.version>
</properties>
②:引用属性
比如spring-context
的版本引用如下,要用${}
表示:
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
1.2、资源文件引用属性【重要】【头条项目中使用到】
①:定义属性(1中)
<!--定义自定义属性-->
<properties>
<spring.version>5.2.10.RELEASE</spring.version>
<junit.version>4.12</junit.version>
<jdbc.url>jdbc:mysql://127.0.0.1:3306/ssm_db</jdbc.url>
</properties>
②:在原配置文件中引用属性(2中)
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=${jdbc.url}
jdbc.username=root
jdbc.password=1234
③:开启资源文件目录加载属性的过滤器(1中)
<!--设置资源目录,并设置能够解析${},设置成true,否则解析不了${}-->
<build>
<resources>
<resource>
<directory>${project.basedir}/src/main/resources</directory>
<filtering>true</filtering>
</resource>
</resources>
</build>
④:配置maven打war包时,忽略web.xml检查(2中)
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<version>3.2.3</version>
<configuration>
<failOnMissingWebXml>false</failOnMissingWebXml>
</configuration>
</plugin>
1.3、其他属性(了解)
- 属性列表
- 自定义属性(常用)
- 内置属性
- Setting属性
- Java系统属性
- 环境变量属性
2、版本管理
问题导入
项目开发的版本可以分为哪几种?
2.1、工程版本
- SNAPSHOT(快照版本)
- 项目开发过程中临时输出的版本,称为快照版本
- 快照版本会随着开发的进展不断更新
- RELEASE(发布版本)
- 项目开发到进入阶段里程碑后,向团队外部发布较为稳定的版本,这种版本所对应的构件文件是稳定的
- 即便进行功能的后续开发,也不会改变当前发布版本内容,这种版本称为发布版本
2.2、发布版本
- alpha版
- beta版
- 纯数字版
五、多环境配置与应用
1、 多环境配置作用
问题导入
多环境配置有什么好处?
- maven提供配置多种环境的设定,帮助开发者使用过程中快速切换环境
2、多环境配置步骤【重要】
2.1、定义多环境(1中)
<!--配置多环境-->
<profiles>
<!--定义具体的环境:生产环境-->
<profile>
<id>env_dep</id>
<!--定义环境中专用的属性值-->
<properties>
<jdbc.url>jdbc:mysql://127.1.1.1:3306/ssm_db</jdbc.url>
</properties>
<!--设定是否为默认启动环境-->
<activation>
<activeByDefault>true</activeByDefault>
</activation>
</profile>
<!--定义具体的环境:开发环境-->
<profile>
<id>env_pro</id>
<properties>
<jdbc.url>jdbc:mysql://127.2.2.2:3306/ssm_db</jdbc.url>
</properties>
</profile>
<!--定义具体的环境:测试环境-->
<profile>
<id>env_test</id>
<properties>
<jdbc.url>jdbc:mysql://127.3.3.3:3306/ssm_db</jdbc.url>
</properties>
</profile>
</profiles>
2.2、使用多环境(构建过程)
除了上面的使用具体的哪一个环境外:
<!--设置默认启动-->
<activation>
<activeByDefault>true</activeByDefault>
</activation>
还有多种方式改变使用的环境
【命令】:
mvn 指令 –P 环境定义id
【范例】:
mvn install –P env_pro
3、跳过测试(了解)
问题导入
跳过测试会不会影响项目的构建过程?
3.1、应用场景
- 功能更新中并且没有开发完毕
- 快速打包
- ……
3.2、跳过测试
方式一:
方式二:命令的方式
mvn install –D skipTests
注意事项:
执行的项目构建指令必须包含测试生命周期,否则无效果。例如执行compile生命周期,不经过test生命周期。
方式三:细粒度控制跳过测试
<plugin>
<artifactId>maven-surefire-plugin</artifactId> <!--测试插件的名称-->
<version>2.22.1</version> <!--测试插件的版本-->
<configuration>
<!--测试插件的配置:是否跳过-->
<skipTests>true</skipTests> <!--是否跳过测试,true代表跳过-->
<!--设置跳过测试-->
<includes>
<!--包含指定的测试用例-->
<include>**/User*Test.java</include>
</includes>
<excludes>
<!--排除指定的测试用例-->
<exclude>**/User*TestCase.java</exclude>
</excludes>
</configuration>
</plugin>
六、私服
1、私服介绍
问题导入
这里的私服和平时我们听的国服、体验服、欧服等等有什么区别?
1.1、介绍
- 私服是一台独立的服务器,用于解决团队内部的资源共享与资源同步问题
- Nexus
- Sonatype公司的一款maven私服产品
- 下载地址:https://help.sonatype.com/repomanager3/download
1.2 Nexus安装与启动
右键打开:latest-win64.zip
将下面的两个文件夹拖出,到任意位置;
在:nexus-3.30.1-01\bin
下输入cmd
,等待一会:
- 启动服务器(命令行启动)
nexus.exe /run nexus
- 访问服务器(默认端口:8081)
http://localhost:8081
(默认端口号是8081,可以改)
- 先点击网页右上角登录,输入用户名和密码(根据提示),点击登录,修改密码为
admin
,然后选择第一项,继续next
,finishi
- 【用户名、密码均为
admin
】
到此启动完毕
- 修改基础配置信息
- 安装路径下etc目录中nexus-default.properties文件保存有nexus基础配置信息,例如默认访问端口。
- 修改服务器运行配置信息
- 安装路径下bin目录中nexus.vmoptions文件保存有nexus服务器启动对应的配置信息,例如默认占用内存空间。
1.3、私服资源操作流程分析
2、私服仓库分类
问题导入
私服仓库分为哪几种?
代理仓库:所有项目组共用一个;
仓库组:每个项目组拥有一个;
宿主仓库:项目组中的每个成员都拥有一个;
3、资源上传与下载
问题导入
往私服上传资源是否需要身份认证?在哪里设置认证信息?
3.0、创建两个自己的私服
创建过程如下;
snapshot:快照
release:发布
创建完毕:
3.1、从私服中下载依赖
【第一步】配置本地仓库访问私服的路径(在maven
的安装目录D:\apache-maven\apache-maven-3.6.1
下的conf
包下的settings.xml
中\<mirrors>
标签中配置,此时就需要注释掉aliyun的配置。)
<!-- 配置私服的访问路径-->
<mirror>
<id>maven-public</id> <!-- 仓库组id-->
<mirrorOf>*</mirrorOf>
<url>http://localhost:8081/repository/maven-public/</url>
</mirror>
注意要记得把我们新建的仓库加入到上面的这个仓库组中
3.2 上传依赖到私服中
【第一步】配置本地仓库访问私服的权限(在maven
的安装目录下的conf
包下的settings.xml的servers标签中配置)
<server>
<!--id任意,多个server的id不重复就行,后面会用到-->
<id>itheima-snapshot</id>
<username>admin</username>
<password>admin</password><!--填写自己nexus设定的登录秘密-->
</server>
<server>
<!--id任意,多个server的id不重复就行,后面会用到-->
<id>itheima-release</id>
<username>admin</username>
<password>admin</password><!--填写自己nexus设定的登录秘密-->
</server>
其中itheima-snapshot
和itheima-release
是要自己创建的自己的私服,类型分别为snapshot
和release
- 配置当前工程保存在私服中的具体位置(在(1)的pom.xml文件中)
<!--配置当前工程保存在私服中的具体位置-->
<distributionManagement>
<repository><!--正式版仓库-->
<id>itheima-release</id>
<url>http://localhost:8081/repository/itheima-release/</url>
</repository>
<snapshotRepository> <!--临时版仓库-->
<id>itheima-snapshot</id>
<url>http://localhost:8081/repository/itheima-snapshot/</url>
</snapshotRepository>
</distributionManagement>
注意:要和maven的settings.xml中server中定义的<id>itheima-release</id>
与<id>itheima-snapshot</id>
对应
【第三步】发布资源到私服命令
如果私服中没有对应的jar,会去中央仓库下载,速度很慢。可以配置让私服去阿里云中下载依赖:(也可以不改)
将
改为
最后点击save