Maven基础知识!
Maven基础知识!
月伴飞鱼基本信息
标 签 | 作 用 |
---|---|
groupId | 通常为组织或公司域名反写 |
artifactId | 项目的名称 |
version | 项目的版本信息 |
name | 项目的简称 |
description | 项目的简要描述 |
生命周期
clean
:
- 清除当前工程编译后生成的文件(即删除
target
整个目录)
validate
:
- 对工程进行基础验证,如工程结构、
pom
、资源文件等是否正确
compile
:
- 对
src/main/java
目录下的源码进行编译(会生成target
目录)
test
:
- 编译并执行
src/test/java/
目录下的所有测试用例
package
:
- 将当前项目打包,普通项目打
jar
包,webapp
项目打war
包
verify
:
- 验证工程所有代码、配置进行是否正确,如类中代码的语法检测等
install
:
- 将当前工程打包,然后安装到本地仓库,别人可通过
GAV
导入
site
:
- 生成项目的概述、源码测试覆盖率、开发者列表等站点文档(需要额外配置)
deploy
:
- 将当前工程对应的包,上传到远程仓库,提供给他人使用(私服会用)
依赖范围
项目引入的所有依赖,如果不显式指定依赖范围,默认是
compile
,意味着所有环境下都生效。一般的依赖包无需更改,只有某些特殊的依赖,才需要手动配置一下,如:
JUnit、spring-test
这类包,只在测试环境使用,所以配成test
Tomcat
内置servlet-api
包,为了避免在运行环境冲突,应该配成provided
依赖范围 | 编译环境 | 测试环境 | 运行环境 |
---|---|---|---|
compile |
生效 | 生效 | 生效 |
provided |
生效 | 生效 | 不生效 |
system |
生效 | 生效 | 不生效 |
runtime |
不生效 | 生效 | 生效 |
test |
不生效 | 生效 | 不生效 |
间接依赖
如果
Dependency-A
引用了Dependency-B
,而Dependency-B
又依赖于Dependency-C
。
- 只需要引入
Dependency-B
即可,Maven
会自动将子模块所依赖的包导入。
依赖顺序:
如工程中引入
Dependency-A
与Dependency-B
两个依赖,二者又分别引用了不同版本的Dependency-C
。但最终编译时同一个依赖即便是不同的版本也只会选择一份。
计算规则:
- 若
Dependency-A
定义在Dependency-B
之前,则最终将导入Dependency-A
中的Dependency-C
版本。
依赖调解
当一个间接依赖存在多条引入路径时,为避免依赖重复Maven会通过依赖调解来确定该间接依赖的引入路径。
依赖调解遵循以下原则,优先使用第一原则,当第一原则无法解决时,则通过第二原则解决。
- 第一原则: 路径最短者优先。
- 第二原则: 第一声明者优先。
可选依赖
当某个间接依赖是可选依赖时,无论依赖范围是什么,其都不会因为传递性依赖机制而被引入。
- 只有显式地配置项目中某依赖的option元素为true时,该依赖才是可选依赖。
排除依赖
在引用多个模块时可能会发生版本兼容冲突问题,通过
exclusions
标签即可实现依赖排除。
1 | <dependency> |
变量配置
当项目中引入了大量依赖,为了方便管理通常将引入依赖的版本通过变量进行统一配置,从而实现更直观的依赖管理。
通过
properties
标签即可自定义变量配置,然后使用${}
引用变量。
1 | <properties> |
模块配置
模块继承:
通过
parent
即可标记当前模块的父模块,且子模块将会继承父模块中的所有依赖配置。
- 子模块若没有指定的
groupId
和version
默认继承父模块中的配置。其中
relativePath
用于指定父模块的POM
文件目录,省略时默认值为../pom.xml
。即当前目录的上一级中,若仍未找到则会在本地仓库中寻找。
1 | <!-- module-1 pom.xml --> |
依赖管理
将项目依赖统一定义在父模块的
dependencyManagement
标签中。子模块只需继承父模块并在
dependencies
引入所需的依赖,便可自动读取父模块dependencyManagement
所指定的版本。
dependencyManagement
既不会在当前模块引入依赖,也不会给其子模块引入依赖,但其可以被继承的。只有在子模块下同样声明了该依赖,才会引入到模块中。
子模块中只需在依赖中引入
groupId
与artifactId
即可,也可以指定版本则会进行覆盖。
1 | <dependencyManagement> |
构建配置
版本指定:
在
<plugin>
标签内可指定工程打包编译时使用的JDK
版本,可根据服务器环境手动修改版本。
1 | <plugins> |
主类配置
在打包时可能出现无法识别工程主类的问题,导致编译后的文件无法正常运行,此时则可以在
pom
文件中手动设置工程的主类。
- 其中
<mainClass>
中配置的为项目主类的完成限定名。
1 | <plugins> |