依赖管理,仓库及构建生命周期
依赖配置
在之前的笔记中,我们详细的给出了依赖声明的语法规则,其中,最重要的,就是依赖坐标。
其中还有一个元素,<scope>,它表示的是依赖作用的范围,常见的值有compile(默认),provided。
<scope>provided</scope>
compile:编译时需要,打包时也会一并包含在内。
provided:仅编译时需要。对于容器会提供的环境依赖文件,我们一般采用provided。
对于用于继承的父pom来说,还有一个元素需要配置,那就是<dependencyMangment>,它包裹在<dependencies>标签外。
那么我们的依赖项,会到哪里去寻找呢?
仓库
Maven仓库是一个用于统一存储所有Maven项目共享构件的空间。
仓库按照位置可以分为两类:
- 本地仓库:用于缓存依赖。默认路径为${user.home}/.m2/repository
- 远程仓库:存放在服务器的仓库,提供maven项目访问并下载构件至本地仓库。通过项目坐标,可以访问到存放在远程仓库的依赖。
已经缓存到本地的依赖,再次使用时可以直接调用,节约带宽。访问仓库时,本地仓库优先查找。
远程仓库按照作用不同,可以分为以下几类:
- 中央仓库 The Central Repository,包含绝大部分开源项目。默认没有任何配置的话,就会从中央仓库查询。
- 其他公共仓库 开源中国社区,一般提供了一个maven的镜像库,加速访问。
- 私服 如公司内部仓库(artifactory),这样对于一些私人项目,也可以托管到私服中。
远程仓库的配置:使用配置文件settings.xml或者在项目的pom.xml中为依赖指定<respositories>属性,这样配置,仅对设置的项目生效。
构建生命周期
一个构建生命周期是一组精心组织的有序的阶段,每一个阶段执行预先定义的"动作",比如:
- 编译
- 打包
- 部署
- ...
这些动作会根据不同的项目类型,会自动的进行选择。
Maven有三套独立的互不干涉的生命周期:
- clean -> pre-clean -> clean -> post-clean
clean主要用来删除项目构建的输出,比如架包,class文件等。
mvn clean
- defalut -> ... -> process-resources -> complie -> ... -> test -> package -> install -> deploy
mvn clean install//两个生命周期
- site -> pre-site -> site -> post-site -> site-deploy
site生命周期主要用来生成站点文档,主要用于开源项目,可以与java docker一起使用。
默认生命周期
default生命周期,是我们的项目构建过程中的整体模型,我们只关注写出来的阶段。
- validate:检测我们的项目配置是否正确,用来构建项目的信息是否完整。
- process-resources:复制资源文件。
- test:单元测试
- package:打包成jar或者war
- install:将包安装到我们的本地仓库,这样在本地开发时,如果有别的项目依赖本项目,就可以直接查找了。
- deploy:将war包上传到远程仓库。
插件和目标
maven是一个插件式的架构,由一个很小的引擎,配上很多插件构成的。
所有的插件本身也是一个maven构建,由mavem仓库进行管理。
maven的所有功能实际上都是由插件提供的。
每一个插件提供多个目标(Goal)。
调用目标的格式:
mvn <plugin>:<Goal>
插件目标绑定构建生命周期
插件在maven的生命周期中占据了很重要的地位,生命构建阶段与目标绑定,当我们在调用maven生命周期时,实际上执行的是maven的插件目标。
用户通过指定生命周期阶段就能隐式的通过插件执行任务。
命令与目标的对应关系:
process-resources resources:resources
compile compiler:compile
test surefire:test
install install:install
deploy deploy:deploy
对于package阶段,会根据项目类型的不同,绑定到不同的目标之上。
插件配置
插件除了有定位的坐标外,还有一个<configuration>元素,用来配置插件。
<configuration>
<source>1.6</source>
<target>1.6</target>
<encoding>UTF-8</encoding>
</configuration>
我们可以通过一个命令来查看插件支持的所有配置项:
mvn help:describe -Dplugin=<plugin_name> -Dgoal=<goal> -Ddetail
插件配置的具体内容,我们将会在下一份笔记中为大家展出~
网友评论