英文:Project Object Model;中文:项目对象模型。
项目版本
主版本.次版本.增量版本.限定版本号:
<major version>.<minor version>.<incremental version>-<qualifier>一个版本“ 5 ”只有主版本 5 ,没有次版本和增量版本。限定版本用来标识里程碑构建: alpha、 beta 等,限定版本通过连字符与主版本,次版本或增量版本隔离。如果版本发布号没有符合本节介绍的标准,那么版本号只会根据字符串排序比较。 Maven 目前对于“ alpha-2 ”和“ alpha-10 ”还是用字符串排序进行比较的,注意改写成“ alpha-10 ”在“ alpha-2 ”。
SNAPSHOT版本
表示此项目正处于开发状态,会不断更新,称为快照版本。实际上每次部署快照版本到中央库的时候会加上时间戳。若依赖一个1.0-SNAPSHOT版本,则本地运行构建的时候总是会从仓库下载最新时间戳的快照版本。目前Maven默认不开启快照版本自动下载功能,需要使用repository或则pluginRepository开启。一般正式发布的项目不能依赖任何快照版本。
LATEST和RELEASE版本
LATEST:最新的版本,不管是快照版还是稳定版。
RELEASE:最新稳定版。
Maven 2.0.9之后,Maven在超级POM中锁住了一些通用及核心Maven插件的版本号。
属性
${}方式引用变量,Maven提供了三个隐式的变量:
env变量,暴露了你操作系统或者shell的环境变量,如${env.PATH}。
project:暴露POM,如${project.groudId}。
settings:暴露Maven Settings(~/.m2/settings.xml)。
支持Java系统属性,一个完整的系统属性列表可以在java.lang.System类的Javadoc中找到。
支持使用<properties>自定义属性。
依赖范围(scope)
compile:编译范围(默认范围),完全范围,最终打包。
provided:已提供范围,指容器已提供,最终不会被打包。
runtime:运行时范围,在运行和测试的时候需要,但在编译时不需要,如在编译的时候只需要JDBC 接口环境,而只有在运行的时候才需要JDBC驱动实现。
test:测试范围,在一般的编译和运行时都不需要,它们只有在测试编译和测试运行阶段可用。
system:系统范围,同provides,引入本地Jar包,结合systemPath使用:
<scope>system</scope> <systemPath>${java.home}/lib/rt.jar</systemPath>
可选依赖
给<dependency>配置<optional>true</optional>,指此依赖不是强制传递性的。如项目ProjectA可选依赖于a.jar,b.jar,ProjectB依赖于ProjectA,ProjectB中可指定只传递依赖于a.jar而不会a.jar和b.jar全部依赖。
依赖版本界限
对于<dependency>的<version>可指定版本界限,如[3.8,4.0)表示任意的大于等于3.8但是小于4.0的版本,逗号前面或者后面的版本不是必须的,空缺意味着正无穷或负无穷,Maven会适当的选择一个合适的最新版本。
传递性依赖
依赖范围一定程度上会影响传递性依赖,如下所示的依赖边界示意图:
例:p1直接依赖于p2(测试范围),p2直接依赖于p3(编译范围),则p1传递依赖于p3(测试范围)。有时不需要传递性依赖,譬如p1只想依赖p2,不需要传递性依赖p3,则可以通过以下配置解决:
<dependency> <groupId>org.sonatype.mavenbook</groupId> <artifactId>project-a</artifactId> <version>1.0</version> <exclusions> <exclusion> <groupId>org.sonatype.mavenbook</groupId> <artifactId>project-b</artifactId> </exclusion> </exclusions> </dependency>
有时候想排除并替换一个传递性依赖,可在以上基础上添加想要的依赖即可。
Classifier:项目限定符,帮助定义构建输出一些附属构建。
项目构件文件名的一般规则是:artifactId-version[-classfier].packaging。
POM继承
Maven假设父POM在本地仓库中可用,或者在当前项目的父目录(../pom.xml) 中可用。
如果两个位置都不可用,默认行为还可以通过relativePath元素被覆盖。
<parent> <groupId>org.sonatype.mavenbook</groupId> <artifactId>a-parent</artifactId> <version>1.0-SNAPSHOT</version> <relativePath>../a-parent/pom.xml</relativePath> </parent>
注意Maven继承和聚合的概念,点击查阅。
依赖归类
形象的说,可以自己归类一部分依赖,通过一个POM类型的打包方式安装到maven仓库(mvn install),以后项目使用可以依赖该POM,相对容易管理。