针对#廖雪峰#《Maven》总结
scope作用域
a) compile(默认值):在编译、运行、测试、打包都有效;
b) provided:编译、测试时有效,运行、打包无效;
c) test:仅在测试时有效;
d) runtime:测试、运行、打包时有效;
e) system:不推荐使用,使用system作用域不会去本地仓库寻找依赖,要指定本地路径。
构建流程
Lifecycle(生命周期) 和 Phase(阶段)
- Clean Lifecycle 在进行真正的构建之前进行一些清理工作。
- Default Lifecycle 构建的核心部分,编译,测试,打包,部署等等。
- Site Lifecycle 生成项目报告,站点,发布站点。
default生命周期
生命周期由一系列阶段构成,以内置的生命周期default为例,它包括以下phase:
- validate 校验
- initialize 初始化
- generate-sources 生成源码
- process-sources 处理源码
- generate-resources 生成资源
- process-resources 复制并处理资源文件,至目标目录,准备打包。
- compile 编译
- process-classes 处理-classes
- generate-test-sources 生成测试源码
- process-test-sources 处理测试源码
- generate-test-resources 生成测试资源
- process-test-resources 复制并处理资源文件,至目标测试目录。
- test-compile 测试编译
- process-test-classes 处理测试-classes
- test 使用合适的单元测试框架运行测试。这些测试代码不会被打包或部署。
- prepare-package 准备打包
- package 接受编译好的代码,打包成可发布的格式,如 JAR 。
- pre-integration-test 预综合测试
- integration-test 综合测试
- post-integration-test 综合测试之后
- verify 核实
- install 将包安装至本地仓库,以让其它项目依赖。
- deploy 将最终的包复制到远程的仓库,以让其它开发人员与项目共享。
如果我们运行mvn package,Maven就会执行default生命周期,他会从开始运行到package这个phase为止:
- validate
- initialize
- ...
- prepare-package
- package
如果我们运行mvn compile,Maven也会执行default生命周期,但这次它只会运行到compile,即以下几个phase:
- validate
- initialize
- ...
- process-resources
- compile
clean生命周期
Maven另一个常用的生命周期是clean,它会执行3个phase:
- pre-clean 执行一些需要在clean之前完成的工作
- clean 移除所有上一次构建生成的文件
- post-clean 执行一些需要在clean之后立刻完成的工作
所以,我们使用mvn这个命令时,后面的参数是phase,Maven自动根据生命周期运行到指定的phase。
site生命周期
- pre-site 执行一些需要在生成站点文档之前完成的工作
- site 生成项目的站点文档
- post-site 执行一些需要在生成站点文档之后完成的工作,并且为部署做准备
- site-deploy 将生成的站点文档部署到特定的服务器上
使用实例
更复杂的例子是指定多个phase,例如,运行mvn clean package,Maven先执行clean生命周期并运行到clean这个phase,然后执行default生命周期并运行到package这个phase,实际执行的phase如下:
- pre-clean
- clean (注意这个clean是phase)
- validate (开始执行default生命周期的第一个phase)
- initialize
- ...
- prepare-package
- package
在实际开发过程中,经常使用的命令有:
mvn clean:清理所有生成的class和jar;
mvn clean compile:先清理,再执行到compile;
mvn clean test:先清理,再执行到test,因为执行test前必须执行compile,所以这里不必指定compile;
mvn clean package:先清理,再执行到package。
大多数phase在执行过程中,因为我们通常没有在pom.xml中配置相关的设置,所以这些phase什么事情都不做。
经常用到的phase其实只有几个:
- clean:清理
- compile:编译
- test:运行测试
- package:打包
Goal
执行一个phase又会触发一个或多个goal:
| 执行的Phase | 对应执行的Goal |
|---|---|
| compile | compiler:compile |
| test | compiler:testCompile surefire:test |
goal的命名总是abc:xyz这种形式。
其实我们类比一下就明白了:
- lifecycle相当于Java的package,它包含一个或多个phase;
- phase相当于Java的class,它包含一个或多个goal;
- goal相当于class的method,它其实才是真正干活的。
大多数情况,我们只要指定phase,就默认执行这些phase默认绑定的goal,只有少数情况,我们可以直接指定运行一个goal,例如,启动Tomcat服务器:
mvn tomcat:run
小结
Maven通过lifecycle、phase和goal来提供标准的构建流程。
最常用的构建命令是指定phase,然后让Maven执行到指定的phase:
- mvn clean
- mvn clean compile
- mvn clean test
- mvn clean package
通常情况,我们总是执行phase默认绑定的goal,因此不必指定goal。