Maven生命周期介绍

生命周期的概念与意义

在项目构建时通常会包含清理、编译、测试、打包、验证、部署,文档生成等步骤,maven 统一对其进行了整理抽像成三个生命周期 (lifecycle)及各自对应的多个阶段(phase)。这么做的意义是:

  1. 每个阶段都成为了一个扩展点,可以采用不同的方式来实现,提高了扩展性与灵活性。
  2. 规范统一了maven 的执行路径。

在执行项目构建阶段时可以采用jar方式构建也可以采用war包方式构建,提高了灵活性。我们可以通过命令 mvn ${phase name}直接触发指定阶段的执行。

maven三大生命周期与其对应的phase(阶段)

maven 总共包含三大生生命周期

  1. clean Lifecycle :清理生命周期,用于于清理项目
  2. default Lifecycle:默认生命周期,用于编译、打包、测试、部署等
  3. site Lifecycle 站点文档生成,用于构建站点文档


    default生命周期.png

上图给出了默认的生命周期的流程图,我么可以看到,生命周期也是抽象的流程概念,具体的实现,则是由相应的jar实现。这就好比抽象类或者接口,仅仅定义标准,也体现了具体场景中的灵活性。

生命周期(lifecycle) 阶段(phase) 描述(describe)
clean Lifecycle pre-clean 预清理
clean 清理
post-clean 清理之后
default Lifecycle validate 验证
initialize 初始化
generate-sources
process-sources
generate-resources
process-resources
compile 编译
process-classes
generate-test-sources
process-test-sources
generate-test-resources
process-test-resources
test-compile 编译测试类
process-test-classes
test 执行测试
prepare-package 构建前准备
package 打包构建
pre-integration-test
integration-test
post-integration-test
verify 验证
install 上传到本地仓库
deploy 上传到远程仓库
site Lifecycle pre-site 准备构建站点
site 构建站点
post-site 构建站点之后
site-deploy 站点部署

三大生命周期可以相互独立执行,也可以合在一起执行。但lifecycle 中的phase 是有严格执行的顺序的,比如必须是先执行完compile 才能执行pakcage 动作,此外phase 还有执行逻辑存在,即当你执行一个phase 时,其前面的phase 会自动执行。

生命周期的phase组成了项目过建的完整过程,但这些过程具体由谁来实现呢?这就是插件,maven 的核心部分代码量其实很少,其大部分实现都是由插件来完成的。比如:test 阶段就是由 maven-surefire-plugin 实现。在pom.xml 中我们可以设置指定插件目标(gogal)与phase 绑定,当项目构建到达指定phase时 就会触发些插件gogal 的执行。 一个插件有时会实现多个phase,比如:maven-compiler-plugin插件分别实现了compile 和testCompile。

在我们的项目当中并没有配置 maven-compiler-plugin 插件,但当我们执行compile 阶段时一样能够执行编译操作,原因是maven 默认为指定阶段绑定了插件实现。

下表列举了各个阶段的默认绑定插件,数据来源于Maven官网
Clean Lifecycle Bindings

Phase plugin:goal
clean clean:clean

Default Lifecycle Bindings - Packaging ear

Phase plugin:goal
generate-resources ear:generate-application-xml
process-resources resources:resources
package ear:ear
install install:install
deploy deploy:deploy

Default Lifecycle Bindings - Packaging jar

Phase plugin:goal
process-resources resources:resources
compile compiler:compile
process-test-resources resources:testResources
test-compile compiler:testCompile
test surefire:test
package jar:jar
install install:install
deploy deploy:deploy

Default Lifecycle Bindings - Packaging maven-plugin

Phase plugin:goal
generate-resources plugin:descriptor
process-resources resources:resources
compile compiler:compile
process-test-resources resources:testResources
test-compile compiler:testCompile
test surefire:test

Site Lifecycle Bindings

Phase plugin:goal
site site:site
site-deploy site:deploy

从表格数据我们可以看出,package阶段绑定插件非常灵活,生成不同的类型包,如jar,war或者ear,对应的默认插件是不同的。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Hello!你好! 这里是心晴的育儿说! 生活中,有些孩子往往不爱说话,尤其是在陌生的环境中几乎...
    H黄老师H阅读 362评论 0 4
  • 我从未体验过生身母亲对我的慈爱,所以当我读到一个市委书记下乡考察时所记录的母亲们时,我早已哽咽成了一个泪人。这些伟...
    知更鸟and花妖阅读 373评论 0 1
  • 前段时间听网上一个讲英语写作的课,黄老师说,对于学生的写作,老师要尽量减少学生的不确定性。 比如学生作文的书写,要...
    啊攀攀了阅读 622评论 4 3
  • 有的人家已开始升火煮早饭了,袅袅炊烟从烟囱中婀娜的漫出来,伴着清晨微微的轻风又慵懒的飘向远方,最后也消失在天空中。...
    风过无痕心易冷阅读 205评论 0 0
  • 我们要经常整理一下自己的生活,看看哪些是我们已拥有却常常忽视的, 那些是我们得不到却一直苦苦追寻的。那些被我们忽视...
    Rita爱阅读 229评论 0 1