文章目录
1. dependency、scope、option、relativePath标签元素
1.1 dependency元素
<dependency>
<groupId></groupId>
<artifactId></artifactId>
<version>版本</version>
<type>依赖的类型,对应于项目的packing,默认是jar</type>
<scope>依赖范围</scope>
<systemPath>配合 scope=system时使用</systemPath>
<optional>标记是否为可选依赖</optional>
<exclusions>
用来排除传递性依赖
<exclusion>
</exclusion>
</exclusions>
</dependency>
1.2 scope
(1)compile:这是依赖项的默认作用范围,即当没有指定依赖项的scope时默认使用compile。compile范围内的依赖项在所有情况下都是有效的,包括运行、测试和编译时;
(2)runtime:表示该依赖项只有在运行时才是需要的,在编译的时候不需要。这种类型的依赖项将在运行和test的类路径下可以访问;
(3)test:表示该依赖项只对测试时有用,包括测试代码的编译和运行,对于正常的项目运行是没有影响的;
(4)provided:表示该依赖项将由JDK或者运行容器在运行时提供,也就是说由Maven提供的该依赖项我们只有在编译和测试时才会用到,而在运行时将由JDK或者运行容器提供;
(5)system:当scope为system时,表示该依赖项是我们自己提供的,不需要Maven到仓库里面去找。指定scope为system需要与另一个属性元素systemPath一起使用,它表示该依赖项在当前系统的位置,使用的是绝对路径;
(6)import:只能用在dependencyManagement里面,且仅用于type=pom的dependency。主要作用: 1. 是将dependency分类;2. 每一类建立单独的pom文件,在需要使用到这些依赖的子model中,使用dependencyManagement管理依赖,并import scope依赖【示例见父子工程】
1.2.1 针对依赖的可见性/可用性
complie | test | provided | |
---|---|---|---|
src->main(主程序) | Y | N | Y |
src->test(测试程序) | Y | Y | Y |
mvn package后(部署) | Y | N | N |
说明:当scope为complile时(默认)则说明(其它同理):
(1)依赖在src->main->java的主程序包下是可以使用的
(2)依赖在src->test->java的测试程序包下是可以使用的
(3)依赖在mvn package打包后,是可以使用的
【todo】注意:在将依赖的scope设置为provided时,我windows本地是打包成功并且测试接口通过了,目前原因未知,请明白的网友告知!!!
1.2.2 针对依赖的传递性
如果A->B->C(A依赖B,B依赖C),那么A能否使用C呢?那要看B依赖C的范围是不是compile,如果是,则可以;如果不是,则不可用
1.3 optional标签
作用:用来控制该依赖是否可以被传递
1.4 relativePath标签
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.4.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
设定一个空值将始终从仓库中获取,不从本地路径获取,如<relativePath />
默认值为…/pom.xml
查找顺序:relativePath元素中的地址 – 本地仓库 – 远程仓库
2. maven包依赖原则
常遇到的问题是,有不同版本的包,他们都存在传递性依赖,如下
a->b->c->x(1.0)
a->b->x(2.0)
所以为了解决jar包冲突,有以下依赖原则:
- 路径最短者优先
- 路径相同时,先声明者优先(即dependency标签配置的顺序)
假设有 a->b,b->x和 b->y的 optional值都是true,那么a对于x和y的依赖不会被传递,如果a想要使用x或y的包,那么需要在a中重新进行依赖
3. maven私服
可以使用nexus搭建maven私服,更多信息可自行查阅资料
4. maven生命周期
Maven 的插件机制是完全依赖 Maven 的生命周期的,因此理解生命周期至关重要。
- clean:项目清理的处理
- default(或 build):项目部署的处理
- site:项目站点文档创建的处理
每套生命周期都由一组阶段(Phase)组成,我们平时在命令行输入的命令总会对应于一个特定的阶段。比如,运行 mvn clean,这个 clean 是 Clean 生命周期的一个阶段。有 Clean 生命周期,也有 clean 阶段
运行任何一个阶段的时候,它前面的所有阶段都会被运行
4.1 Clean 生命周期
Clean 生命周期一共包含了三个阶段:
- pre-clean 执行一些需要在 clean 之前完成的工作
- clean 移除所有上一次构建生成的文件
- post-clean 执行一些需要在 clean 之后立刻完成的工作
4.2 Default 生命周期
是 Maven 生命周期中最重要的一个,绝大部分工作都发生在这个生命周期中。这里只简单列举几个:
生命周期阶段 | 描述 |
---|---|
validate(校验) | 校验项目是否正确并且所有必要的信息可以完成项目的构建过程。 |
… | … |
compile(编译) | 编译项目的源代码 |
… | … |
test(测试) | 使用合适的单元测试框架运行测试(Juint是其中之一) |
… | … |
package(打包) | 将编译后的代码打包成可分发格式的文件,比如JAR、WAR或者EAR文件 |
… | … |
verify (验证) | 运行任意的检查来验证项目包有效且达到质量标准 |
install(安装) | 安装项目包到本地仓库,这样项目包可以用作其他本地项目的依赖 |
deploy(部署) | 将最终的项目包复制到远程仓库中与其他开发者和项目共享 |
4.3 Site 生命周期
Maven Site 插件一般用来创建新的报告文档、部署站点等
略
5. Maven插件和目标
- Maven 的核心仅仅定义了抽象的生命周期,具体的任务都是交由插件完成的
- 每个插件都能实现多个功能,每个功能就是一个插件目标
- Maven 的生命周期与插件目标相互绑定,以完成某个具体的构建任务
例如:compile 就是插件 maven-compiler-plugin 的一个目标;pre-clean 是插件 maven-clean-plugin 的一个目标
6. idea中依赖树查询
命令
mvn dependency:tree
插件方式
安装maven helper插件,使用其查看pom jar包依赖更加方便快捷
7. 父子工程
父pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.example</groupId>
<artifactId>parent</artifactId>
<version>1.0.0</version>
<packaging>pom</packaging>
<name>父项目</name>
<modules>
<module>子项目</module>
</modules>
<properties>
<java.version>1.8</java.version>
<java.encoding>UTF-8</java.encoding>
</properties>
<dependencyManagement>
<dependencies>
<!--SpringBoot-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${springboot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!--SpringCloud-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<source>${java.version}</source>
<target>${java.version}</target>
<encoding>${java.encoding}</encoding>
</configuration>
</plugin>
</plugins>
</build>
</project>
子项目:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<!-- 父项目的GAV -->
</parent>
<!-- 子项目的GAV -->
<groupId></groupId>
<artifactId></artifactId>
<version></version>
<name></name>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<!-- 子项目引入的实际依赖,版本号自动从父项目继承 -->
</dependencies>
<build>
<plugins>
<!-- 该插件的主要功能是进行项目的打包发布处理 -->
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>${springboot.version}</version>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>