Maven项目管理工具
1. Maven基础
1.1 Maven基础概念
1.1.1 仓库
- 仓库:用于存储资源,包含各种jar包
- 仓库分类:
- 本地仓库:自己电脑上存储资源的仓库,连接远程仓库获取资源
- 远程仓库:非本机电脑上的仓库,为本地仓库提供资源
- 中央仓库:Maven团队维护,存储所有资源的仓库
- 私服:部门/公司范围内存储资源的仓库,从中央仓库获取资源
- 私服的作用:
- 保存具有版权的资源,包含购买或自主研发的jar
- 中央仓库中的jar都是开源的,不能存储具有版权的资源
- 一定范围内共享资源,仅对内部开放,不对外共享
- 保存具有版权的资源,包含购买或自主研发的jar
1.1.2 坐标
-
什么是坐标?
Maven中的坐标用于描述仓库中资源的位置 -
Maven坐标主要组成
groupId:定义当前Maven项目隶属组织名称(通常是域名反写,例如:org.mybatis)
artifactId:定义当前Maven项目名称(通常是模块名称,例如CRM、SMS)
version:定义当前项目版本号
packaging:定义该项目的打包方式
-
Maven坐标的作用
使用唯一表示,唯一性定位资源位置,通过该表示可以将资源的识别与下载工作交由机器完成
1.1.3 仓库配置
本地仓库配置
Maven启动后,会自动保存下载的资源到本地仓库
-
默认位置:
<localRepository>${user.home}/.m2/repository</localRepository>
-
自定义位置:
<localRepository>D:\maven\repository</localRepository>
远程仓库配置
-
Maven默认连接的仓库位置
<repositories> <repository> <id>central</id> <name>Central Repository</name> <url>https://repo.maven.apache.org/maven2</url> <layout>default</layout> <snapshots> <enabled>false</enabled> </snapshots> </repository> </repositories>
镜像仓库配置
-
在setting文件中配置阿里云镜像仓库
<!-- 阿里镜像仓库 --> <mirror> <id>alimaven</id> <name>aliyun maven</name> <url>http://maven.aliyun.com/nexus/content/groups/public/</url> <mirrorOf>central</mirrorOf> </mirror>
1.2 依赖管理
1.2.1 依赖配置
-
依赖指当前项目运行所需的jar,一个项目可以设置多个依赖
-
格式:
<!-- 设置当前项目所依赖的所有jar--> <dependencies> <!—- 设置具体的依赖--> <dependency> <!—- 依赖所属群组id--> <groupId>junit</groupId> <!—- 依赖所属项目id--> <artifactId>junit</artifactId> <!—- 依赖版本号--> <version>4.12</version> </dependency> </dependencies>
1.2.2 依赖传递
- 依赖具有传递性
- 直接依赖:在当前项目中通过依赖配置建立的依赖关系
- 间接依赖:被资源的资源如果依赖其他资源,当前项目简介依赖其他资源
- 依赖传递冲突问题
- 路径优先:当依赖中出现相同的资源时,层级越深,优先级越低,层级越浅,优先级越高
- 声明优先:当资源在相同层级被依赖时,配置顺序靠前的覆盖配置顺序靠后的
- 特殊有限:当同级配置了相同资源的不同版本,后配置的覆盖先配置的
1.2.3 可选依赖
-
可选依赖指对外隐藏当前所依赖的资源——不透明
<dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> <optional>true</optional> </dependency>
1.2.4 排除依赖
-
排除依赖指主动断开依赖的资源,被排除的资源无需指定版本——不需要
<dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> <exclusions> <exclusion> <groupId>org.hamcrest</groupId> <artifactId>hamcrest-core</artifactId> </exclusion> </exclusions> </dependency>
1.2.5 依赖范围
-
依赖的jar默认情况可以在任何地方使用,可以通过scope标签设定其作用范围
-
作用范围
- 主程序范围有效(main文件夹范围内)
- 测试程序范围有效(test文件夹范围内)
- 是否参与打包(package指令范围内)
1.3 生命周期与插件
1.3.1 构建生命周期
- 项目构建生命周期
- clean:清理工作
- default:核心工作,例如编译,测试,打包,部署等
- site:产生报告,发布站点等
- clean生命周期
- pre-clean:执行一些需要在clean之前完成的工作
- clean:移除所有上一次构建生成的文件
- post-clean:执行一些需要在clean之后立刻完成的工作
- default构建生命周期
- validate(校验) 校验项目是否正确并且所有必要的信息可以完成项目的构建过程。
- initialize(初始化) 初始化构建状态,比如设置属性值。
- generate-sources(生成源代码) 生成包含在编译阶段中的任何源代码。
- process-sources(处理源代码) 处理源代码,比如说,过滤任意值。
- generate-resources(生成资源文件) 生成将会包含在项目包中的资源文件。
- process-resources (处理资源文件) 复制和处理资源到目标目录,为打包阶段最好准备。
- compile(编译) 编译项目的源代码。
- process-classes(处理类文件) 处理编译生成的文件,比如说对Java class文件做字节码改善优化。
- generate-test-sources(生成测试源代码) 生成包含在编译阶段中的任何测试源代码。
- process-test-sources(处理测试源代码) 处理测试源代码,比如说,过滤任意值。
- generate-test-resources(生成测试资源文件) 为测试创建资源文件。
- process-test-resources(处理测试资源文件) 复制和处理测试资源到目标目录。
- test-compile(编译测试源码) 编译测试源代码到测试目标目录.
- process-test-classes(处理测试类文件) 处理测试源码编译生成的文件。
- test(测试) 使用合适的单元测试框架运行测试(Juint是其中之一)。
- prepare-package(准备打包) 在实际打包之前,执行任何的必要的操作为打包做准备。
- package(打包) 将编译后的代码打包成可分发格式的文件,比如JAR、WAR或者EAR文件。
- pre-integration-test(集成测试前) 在执行集成测试前进行必要的动作。比如说,搭建需要的环境。
- integration-test(集成测试) 处理和部署项目到可以运行集成测试环境中。
- post-integration-test(集成测试后) 在执行集成测试完成后进行必要的动作。比如说,清理集成测试环境。
- verify (验证) 运行任意的检查来验证项目包有效且达到质量标准。
- install(安装) 安装项目包到本地仓库,这样项目包可以用作其他本地项目的依赖。
- deploy(部署) 将最终的项目包复制到远程仓库中与其他开发者和项目共享。
- site构建生命周期
- pre-site:执行一些需要在生成站点文档之前完成的工作
- site:生成项目的站点文档
- post-site:执行一些需要在生成站点文档之后完成的工作,并且为部署做准备
- site-deploy:将生成的站点文档部署到特定的服务器上
1.3.2 插件
-
插件与生命周期内的阶段绑定,在执行到对应生命周期时执行对应的插件功能
-
默认maven在哥哥生命周期上绑定有预设的功能
-
通过插件可以自定义其他功能
<build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-source-plugin</artifactId> <version>2.2.1</version> <executions> <execution> <goals> <goal>jar</goal> </goals> <phase>generate-test-resources</phase> </execution> </executions> </plugin> </plugins> </build>
2. Maven高级
2.1 聚合
-
作用:聚合用于快速构建maven工程,一次性构建多个项目模块
-
制作方式:
- 创建一个空模块,打包类型定义为pom
<packaging>pom</packaging>
- 定义当前模块进行构建操作时关联的其他模块名称
<modules> <module>../ssm_controller</module> <module>../ssm_service</module> <module>../ssm_dao</module> <module>../ssm_pojo</module> </modules>
-
注意:参与聚合操作的模块最终执行顺序与模块间的依赖关系有关,与配置顺序无关
2.2 继承
-
作用:通过继承可以实现在子工程中沿用父工程中的配置
- maven中的继承与java中的继承相似,在子工程中配置继承关系
-
制作方式:
- 在子工程中声明其父工程坐标与对应的位置
<!-- 定义该工程的父工程 --> <parent> <groupId>com.itheima</groupId> <artifactId>ssm</artifactId> <version>1.0-SNAPSHOT</version> <!-- pom --> <relativePath>../ssm/pom.xml</relativePath> </parent>
继承依赖定义
-
在父工程中定义依赖管理
<!-- 声明此处进行依赖管理 --> <dependencyManagement> <!-- 具体的依赖 --> <dependencies> <!--spring 环境 --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>5.1.9.RELEASE</version> </dependency> <dependencies> <dependencyManagement>
继承依赖使用
-
在子工程中定义依赖关系,无需声明依赖版本,版本参照父工程中依赖的版本
<dependencies> <!--spring 环境 --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> </dependency> </dependencies>
继承与聚合
- 作用
- 聚合用于快速构建项目
- 继承用于快速配置
- 相同点:
- 聚合与继承的pom.xml文件打包方式均为pom,可以将两种关系制作到同一个pom文件中
- 聚合与继承均属于设计型模块,并无实际的模块内容
- 不同点:
- 聚合是在当前模块中配置关系,聚合可以感知到参与聚合的模块有哪些
- 继承是在子模块中配置关系,父模块无法感知到哪些子模块继承了自己
2.3 属性
2.3.1 属性类别
- 自定义属性
- 内置属性
- Setting属性
- Java系统属性
- 环境变量属性
2.3.2 属性类别:自定义属性
-
作用:
- 等同于定义变量,方便统一维护
-
定义格式
<!-- 定义自定义属性 --> <properties> <spring.version>5.1.9.RELEASE</spring.version> <junit.version>4.12</junit.version> </properties>
-
调用格式
<dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>${spring.version}</version> </dependency>
2.3.3 属性类别:内置属性
-
作用
- 使用maven内置属性,快速配置
-
调用格式:
${basedir} ${version}
2.3.4 属性类别:Setting属性
-
作用
- 使用Maven配置文件setting.xml中的标签属性,用于动态配置
-
调用格式:
${settings.localRepository}
2.3.5 属性类别:Java系统属性
-
作用
- 读取Java系统属性
-
调用格式
${user.home}
-
系统属性查询方式
mvn help:system
2.3.6 属性类别:环境变量属性
-
作用
- 使用Maven配置文件setting.xml中的标签属性,用于动态配置
-
调用格式
${env.JAVA_HOME}
-
环境变量属性查询方式
mvn help:system
2.4 版本管理
工程版本
- SNAPSHOT(快照版本)
- 项目开发过程中,为方便团队成员合作,解决模块间相互依赖和实时更新的问题,开发这对每个模块进行构建的时候,输出的临时性版本叫快照版本(测试阶段版本)
- 快照版本会随着开发的进展不断更新
- RELEASE(发布版本)
- 项目开发进入阶段里程碑后,向团队外部发布较为稳定的版本,这种版本所对应的构件文件是稳定的,即便进行功能的后续开发,也不会改变当前发布版本内容,这种版本称为发布版本
工程版本号约定
- 约定规范:
- <主版本>.<次版本>.<增量版本>.<里程碑版本>
- 主版本:表示项目重大架构的变更,如:spring5相较于spring4的迭代
- 次版本:表示有较大的功能增加和变化,或者全面系统地修复漏洞
- 增量版本:表示有重大漏洞的修复
- 里程碑版本:表明一个版本的里程碑(版本内部)。这样的版本同下一个正式版本相比,相对来说不是很稳定,有待更多的测试
- 范例:
- 5.1.9.RELEASE
2.5 资源配置
资源配置多文件维护
<!-- 定义自定义属性 -->
<properties>
<spring.version>5.1.9.RELEASE</spring.version>
<junit.version>4.12</junit.version>
</properties>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>${junit.version}</version>
</dependency>
配置文件引用pom属性
-
作用
- 在任意配置文件中加载pom文件中定义的属性
-
调用格式
${jdbc.url}
-
开启配置文件加载pom属性
<!-- 配置资源文件对应的信息 --> <resources> <resource> <!—-设定配置文件对应的位置目录,支持使用属性动态设定路径--> <directory>${project.basedir}/src/main/resources</directory> <!--开启对配置文件的资源加载过滤--> <filtering>true</filtering> </resource> </resources>
2.6 多环境开发配置
2.6.1 多环境配置
<!-- 创建多环境 -->
<profiles>
<!-- 定义具体的环境:生产环境 -->
<profile>
<!-- 定义环境对应的唯一名称 -->
<id>pro_env</id>
<!-- 定义环境中专用的属性值 -->
<properties>
<jdbc.url>jdbc:mysql://127.1.1.1:3306/ssm_db</jdbc.url>
</properties>
<!-- 设置默认启动 -->
<activation>
<activeByDefault>true</activeByDefault>
</activation>
</profile>
<!-- 定义具体的环境 -->
<profile>
<id>dev_env</id>
……
</profile>
</profiles>
2.6.2 加载指定环境
-
作用
- 加载指定环境配置
-
调用格式
mvn 指令 –P 环境定义id
-
范例
mvn install –P pro_env
2.7 跳过测试
2.7.1 跳过测试环节的应用场景
- 整体模块功能未开发
- 模块中某个功能未开发完毕
- 单个功能呢更新调试导致其他功能失败
- 快速打包
2.7.2 使用命令跳过测试
-
命令
mvn 指令 -D skipTests
-
注意事项
- 执行的指令生命周期必须包含测试环节
2.7.3 使用界面操作跳过测试
2.7.4 使用配置跳过测试
<plugin>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.22.1</version>
<configuration>
<skipTests>true</skipTests><!-- 设置跳过测试-->
<includes> <!-- 包含指定的测试用例-->
<include>**/User*Test.java</include>
</includes>
<excludes><!-- 排除指定的测试用例-->
<exclude>**/User*TestCase.java</exclude>
</excludes>
</configuration>
</plugin>
2.8 私服
Nexus是Sonatype公司的一款maven私服产品
下载地址:https://help.sonatype.com/repomanager3/download
Nexus安装、启动与配置
-
启动服务器(命令行启动)
nexus.exe /run nexus
-
访问服务器(默认端口:8081)
http://localhost:8081
-
修改基础配置信息
- 安装路径下etc目录中nexus-default.properties文件保存有nexus基础配置信息,例如默认访问端口
-
修改服务器运行配置信息
- 安装路径下bin目录中nexus.vmoptions文件保存有nexus服务器启动对应的配置信息,例如默认占用内存空间