Maven
的所有构件均通过坐标进行组织和管理。Maven
的坐标通过5个元素进行定义,其中groupId
、artifactId
、version
是必须的,packaging
是可选的(默认为jar
),classifier
是不能直接定义的。
Maven使用groupId
、artifactId
、version
唯一确定坐标,每个坐标都唯一的指向一个Maven
项目,包名应与groupId
+artifactId
相吻合。
项目组织唯一的标识符,一般为反写的公司网址+项目名,跟Java
包名类似,通常与域名反向一一对应。
项目的唯一的标识符,一般为项目名+模块名,定义当前Maven
项目的一个模块,默认情况下,Maven
生成的构件,其文件名会以artifactId
开头,如hibernate-core-3.6.5.Final.jar
。
定义项目版本号:x.x.x+版本类型
常见版本类型:
SNAPSHOT
快照ALPHA
内部测试BEAT
公测RELEASE
稳定GA
正式发布定义项目打包方式。如jar
、war
、pom
、zip
等,默认为jar
。
定义项目的附属构件,如hibernate-core-3.6.6.Final-sources.jar
,hibernate-core-3.6.6.Final-javadoc.jar
,其中sources
和javadoc
就是这两个附属构件的classifier
。classifier
不能直接定义,通常由附加的插件帮助生成。
Maven
有三套相互独立的生命周期,分别是clean
、default
和site
。每个生命周期包含一些阶段(phase
),阶段是有顺序的,后面的阶段依赖于前面的阶段。
清理项目,包含三个phase
:
pre-clean
执行清理前需要完成的工作clean
清理上一次构建生成的文件post-clean
执行清理后需要完成的工作构建项目,重要的phase
如下:
validate
验证工程是否正确,所有需要的资源是否可用initialize
generate-sources
process-sources
generate-resources
process-resources
复制和处理资源文件到target
目录,准备打包**compile**
** 编译项目的源代码**process-classes
generate-test-sources
process-test-sources
generate-test-resources
process-test-resources
**test-compile**
** 编译测试源代码**process-test-classes
**test**
** 使用合适的单元测试框架来测试已编译的源代码**prepare-package
**package**
** 把已编译的代码打包成可发布的格式,比如****jar**
pre-integration-test
integration-test
如有需要,将包处理和发布到一个能够进行集成测试的环境post-integration-test
verify
运行所有检查,验证包是否有效且达到质量标准**install**
** 将打好的包安装到本地仓库,供其他项目使用**deploy
将打好的包安装到远程仓库,供其他项目使用建立和发布项目站点,phase
如下:
pre-site
生成项目站点之前需要完成的工作site
生成项目站点文档post-site
生成项目站点之后需要完成的工作site-deploy
将项目站点发布到服务器执行不同的Maven
命令,比如mvn package
、mvn test
、mvn install
等,会使用不同的classpath
。Maven
对应的有三套classpath
:编译、测试、运行。scope
选项的值,决定了该依赖构件会被引入到哪一个classpath
中。**scope**
标签:
compile
默认,编译、测试、运行均有效[会传递]provided
在编译和测试时有效,如servletAPI
可以加入[不传递]runtime
在测试和运行时有效,如JDBCAPI
可以加入test
在测试时有效,如junit
可以加入system
在编译和测试时有效,与本机系统相关联,移植性差,在系统中以外部jar
包的形式引入,不会在仓库中查找import
导入,只能用在dependecyManagement
中,表示从其他pom
中导入dependecy
的配置如果C依赖B、B依赖A,则C→B→A
。那么此时C也会依赖A且会包含A中的依赖,这就是传递依赖。消除传递依赖:需要使用
标签。
当多个传递性依赖中有对同一构件不同版本的依赖时,依赖传递原则:
假如有以下依赖:A ->B ->C ->X
(版本1.0
) 和A ->D ->X
(版本2.0
),则优先解析较短路径的 X(版本 2.0)。
若路径长度相同,则谁先声明,谁被解析。
3.4 依赖排除使用依赖排除
元素,显示排除短路径依赖。
通常在项目中,我们会同时依赖同一个构件的不同模块,如spring-orm-3.2.0
、spring-context-3.2.0
,且多个模块版本相同。为了维护和升级方便,我们可以对其同一管理,这时可以使用到Maven
属性,类似于变量的概念。
3.2.0.RELEASE org.springframework spring-orm ${springframework.version} org.springframework spring-context ${springframework.version}
4. 聚合和继承
4.1 聚合在一个项目中,分模块使用了Maven
,那么可能在这个项目中会有五六个,或者更多的Maven
项目存在。如果此时需要编译或测试要怎么办呢,进入每个Maven
项目中进行mvn compile
么,那就要执行五六次的compile
命令,十分繁琐,这里就可以用Maven
的聚合来解决这个问题。
A B C
4.2 继承如果多个Maven
项目具有相同的依赖时或配置时,那么应该如何处理呢?这里就用到继承的概念,在Maven
中使用
标签来进行继承。
4.0.0 com.xxx parent 1.0.0-SNAPSHOT pom UTF-8 4.12 2.4 junit junit ${junit.version} test commons-io commons-io ${commons-io.version}
4.0.0 com.xxx parent 1.0.0-SNAPSHOT com.xxx child 1.0.0-SNAPSHOT jar commons-io commons-io
5. 常用标签1.0.0 com.xxx xxx-cloud 1.0.0-SNAPSHOT jar xxx-xxx xxx https://git.xxx.com UTF-8 junit junit 3.8.1 test false
6. 常用命令mvn -v
查看maven
版本及其他相关信息mvn compile
编译maven
项目,并生成target
文件夹mvn test
运行test
目录下的测试文件,即测试mvn package
将项目打包,默认打包为jar
格式,也可以打包成war
格式用于服务器运行mvn install
将打包的jar
文件安装到maven
本地仓库mvn clean
删除targert
,相当于清除缓存所有的子项目中,不能使用指定依赖版本,所有依赖在父级pom
中使用dependencyManagement
声明,在properties
中统一维护版本。
1.0.0 com.xxx cloud 1.0.0-SNAPSHOT pom 2.4 commons-io commons-io ${commons-io.version}
4.0.0 com.xxx cloud 1.0.0-SNAPSHOT com.xxx aaa 1.0.0-SNAPSHOT jar commons-io commons-io
你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧