𝓝𝓮𝓶𝓸&博客

【Maven】生命周期

Maven 有三个相互独立的生命周期:Clean 生命周期、build 生命周期、site 生命周期。

  • 各个构建环节执行的顺序:不能打乱顺序,必须按照既定的正确顺序来执行。
  • Maven 的核心程序中定义了抽象的生命周期,生命周期中各个阶段的具体任务是由插件来完成的。
  • Maven 核心程序为了更好的实现自动化构建,按照这一特点执行生命周期中的各个阶段:不论现在要执行生命周期中的哪一个阶段,都是从这个生命周期最初的位置开始执行。

Maven 构建的生命周期

Maven 构建生命周期定义了一个项目构建跟发布的过程。

一个典型的 Maven 构建(build)生命周期是由以下几个阶段的序列组成的:

阶段 处理 描述
验证 validate 验证项目 验证项目是否正确且所有必须信息是可用的
编译 compile 执行编译 源代码编译在此阶段完成
测试 Test 测试 使用适当的单元测试框架(例如JUnit)运行测试。
包装 package 打包 创建JAR/WAR包如在 pom.xml 中定义提及的包
检查 verify 检查 对集成测试的结果进行检查,以保证质量达标
安装 install 安装 安装打包的项目到本地仓库,以供其他项目使用
类比git commit
部署 deploy 部署 拷贝最终的工程包到远程仓库中,以共享给其他开发人员和工程
类比git push

为了完成 default 生命周期,这些阶段(包括其他未在上面罗列的生命周期阶段)将被按顺序地执行。

理解:大家可以粗略的认为Maven就是一个存放jar包的Git
它的deploy就相当于把整个文件打包成jar包,然后安装到本地仓库,部署上传到远程仓库。
使用的时候也只是把远程仓库的jar包拉取到本地,依赖使用。

注意:不要认为编译、测试、打包这些东西我们的编译器都可以做 Maven 就不需要了,Maven 在使用父工程将子模块进行聚合的时候,我们就需要这些东西来帮我们运行整个父工程,将子模块的功能整合起来运行。

如果需要查看jar包具体依赖了哪些包,可以考虑使用解压命令解压jar包,如jar -xvzf file.jarunzip file.jar等。


  • validate为了下面的compile操作进行的校验,保证代码是可以进行编译的,没有语法错误等异常

  • test为了下面的package操作进行的校验,保证代码是可以通过UT(Unit Test,单元测试)的,无误之后才会进行打包使用

  • verify为了下面的install操作进行的最终校验,保证代码集成之后测试质量达标,在执行验证之前,verify命令以顺序(验证,编译,包等)执行每个默认生命周期阶段。在大多数情况下,效果与package相同。但是,如果有集成测试,则这些也将执行。在verify阶段期间,可以完成一些额外的检查,例如,如果您的代码根据预定义的Checkstyle规则编写。(如 对jar包进行一些检查等

结论:如果您想运行集成测试并检查它,请使用验证。如果您只想运行单元测试,请使用测试。

我的个人建议:如果有疑问,请使用验证。


test和verify有什么区别?

First of all, when you run a Maven goal, it will run any previous goal. The order of basic phases is:

  • Validate
  • Compile
  • Test
  • Package
  • Verify
  • Install
  • Deploy

If you run Test, Maven will execute validate, compile and test. Based on this, the first point is that verify includes test.

Based on official documentation:

  • TEST - test the compiled source code using a suitable unit testing framework. These tests should not require the code be packaged or deployed
  • VERIFY - run any checks on results of integration tests to ensure quality criteria are met

To run unit tests, the Surefire plugin is recommended. And Failsafe for integration tests.

The verify command executes each default lifecycle phase in order (validate, compile, package, etc.), before executing verify. In most cases the effect is the same as package. However, in case there are integration tests, these will be executed as well. And during the verify phase some additional checks can be done, e.g. if your code is written according to the predefined checkstyle rules.

Conclusion: if you want to run your integration tests and check it, use verify. If you only want to run unit tests, use test.

My personal advice: if in doubt, use verify.

完整生命周期

Maven 有以下三个标准的生命周期:

  • clean:项目清理的处理
  • default(或 build):项目部署的处理
  • site:项目站点文档创建的处理

Clean 生命周期

清理:将以前编译器得到的旧的 class 字节码文件删除,为下一次编译做准备。
当我们执行 mvn post-clean 命令时,Maven 调用 clean 生命周期,它包含以下阶段:

pre-clean:执行一些需要在clean之前完成的工作
clean:移除所有上一次构建生成的文件
post-clean:执行一些需要在clean之后立刻完成的工作

clean

清除已经存在的目标文件target
image
也就是把这个文件删掉

Default (Build) 生命周期

这是 Maven 的主要生命周期,被用于构建应用,包括下面的 23 个阶段:

生命周期阶段 描述
validate(校验) 校验项目是否正确并且所有必要的信息可以完成项目的构建过程。
initialize(初始化) 初始化构建状态,比如设置属性值。
generate-sources(生成源代码) 生成包含在编译阶段中的任何源代码。
process-sources(处理源代码) 处理源代码,比如说,过滤任意值。
generate-resources(生成资源文件) 生成将会包含在项目包中的资源文件。
process-resources (处理资源文件) 复制和处理资源到目标目录,为打包阶段最好准备。
compile(编译) 编译项目的源代码。
process-classes(处理类文件) 处理编译生成的文件,比如说对Java class文件做字节码改善优化。
generate-test-sources(生成测试源代码) 生成包含在编译阶段中的任何测试源代码。
process-test-sources(处理测试源代码) 处理测试源代码,比如说,过滤任意值。
generate-test-resources(生成测试资源文件) 为测试创建资源文件。
process-test-resources(处理测试资源文件) 复制和处理测试资源到目标目录。
test-compile(编译测试源码) 编译测试源代码到测试目标目录.
process-test-classes(处理测试类文件) 处理测试源码编译生成的文件。
test(测试) 使用合适的单元测试框架运行测试(Juint是其中之一)。
prepare-package(准备打包) 在实际打包之前,执行任何的必要的操作为打包做准备。
package(打包) 将编译后的代码打包成可分发格式的文件,比如JAR、WAR或者EAR文件。
pre-integration-test(集成测试前) 在执行集成测试前进行必要的动作。比如说,搭建需要的环境。
integration-test(集成测试) 处理和部署项目到可以运行集成测试环境中。
post-integration-test(集成测试后) 在执行集成测试完成后进行必要的动作。比如说,清理集成测试环境。
verify (验证) 运行任意的检查来验证项目包有效且达到质量标准。
install(安装) 安装项目包到本地仓库,这样项目包可以用作其他本地项目的依赖。
deploy(部署) 将最终的项目包复制到远程仓库中与其他开发者和项目共享。

compile

编译项目,生成目标文件target,文件中都是编译出来的字节码文件
image

package

打包项目,生成jar包放在目标文件target中
image

install

在本地Repository中安装刚刚生成的jar包

deploy

将刚刚生成的jar包推送到远程Repository中

Site 生命周期

Maven Site 插件一般用来创建新的报告文档、部署站点等。

pre-site:执行一些需要在生成站点文档之前完成的工作
site:生成项目的站点文档
post-site:执行一些需要在生成站点文档之后完成的工作,并且为部署做准备
site-deploy:将生成的站点文档部署到特定的服务器上
这里经常用到的是site阶段和site-deploy阶段,用以生成和发布Maven站点,这可是Maven相当强大的功能,Manager比较喜欢,文档及统计数据自动生成,很好看。

posted @ 2020-06-27 15:03  Nemo&  阅读(257)  评论(0编辑  收藏  举报