项目构建的生命周期,其实软件开发人员每天都在干这个事,即项目清理、初始化、编译、测试、打包、集成测试、验证、部署和站点生成等,可以说几乎所有项目的构建都可以映射到这样一个生命周期上。
Maven的插件机制是完全依赖Maven的生命周期的。
三套生命周期
Maven的生命周期并不是一个整体,Maven拥有三套独立的生命周期,它们分别是clean\default\site。Clean生命周期的目的是清理项目,default生命周期的目的是构建项目,而site的生命周期的目的是建立项目站点。
每个生命周期包含一些阶段,这些阶段是有序的,并且后面的阶段依赖于前面的阶段,用户和Maven最直接的交互方式是调用这些生命周期阶段。如clean生命周期,它包含pre-clean\clean\post-clean三个阶段,当用户调用clean阶段时,pre-clean\clean两个阶段会顺序执行,当用户调用post-clean阶段时,pre-clean\clean\post-clean三个阶段会顺序执行。
clean
Clean生命周期一共包含了三个阶段:
- pre-clean 执行一些需要在clean之前完成的工作
- clean 移除所有上一次构建生成的文件
- post-clean 执行一些需要在clean之后立刻完成的工作
default
Maven的Default生命周期,绝大部分工作都发生在这个生命周期中,这里,我只解释一些比较重要和常用的阶段:
- validate
- 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 接受编译好的代码,打包成可发布的格式,如 JAR 。
- pre-integration-test
- integration-test
- post-integration-test
- verify
- install 将包安装至本地仓库,以让其它项目依赖。
- deploy 将最终的包复制到远程的仓库,以让其它开发人员与项目共享。
site
最后,Maven的site生命周期阶段:
- pre-site 执行一些需要在生成站点文档之前完成的工作
- site 生成项目的站点文档
- post-site 执行一些需要在生成站点文档之后完成的工作,并且为部署做准备
- site-deploy 将生成的站点文档部署到特定的服务器上
插件与生命周期绑定,我们在调用命令的时候,其实质是调用了maven插件,而一个插件往往又对应许多个插件目标,具体的周期阶段的完成由插件目标执行。