Maven生命周期和插件机制
Maven中的一个非常重要的概念是生命周期和插件,这篇文章重点介绍下Maven的生命周期。
Maven的生命周期是抽象的,具体的功能是有具体的插件来完成的,Maven有相当多的功能插件,以至于Maven在项目管理上无所不能。Maven从大量的项目构件工具中学习和反思,总结出一套高度完善、易于扩展的生命周期,这个生命周期包含项目的清理、初始化、编译、测试、打包、集成测试、验证、部署和站点生成等几乎所有构件步骤。
在重复说一下Maven的生命周期是抽象的,本身不做任何工作,实际的任务都是交由插件来完成的。
Maven插件机制,Maven设计了插件机制来完成具体的任务,也就是项目的每一个构件步骤都可以绑定一个或多个插件行为,而且Maven为大多数构件步骤绑定默认的插件,例如针对编译的插件有maven-compiler-plugin,针对测试的插件有maven-surefire-plugin等,在一些特殊的需求时,用户可以配置插件定制构件行为,也可以自己编写插件。
Maven的生命周期详解:
Maven有三套项目独立的生命周期,他们分别是clean 、 default 、site 。
clean是项目清理的生命周期。
default是构件项目的生命周期。
site是建立项目站点生命周期。
三套独立的生命周期的每一个生命周期都包含一些阶段,这些阶段是有顺序的,并且后面的阶段依赖前面的阶段,用户最直接的方式就是调用这些生命周期阶段。再次强调三套生命周期是互相独立的,每一套生命周期里面的一些阶段是相互有顺序的互相依赖的。
下面介绍每一套生命周期:
1. clean生命周期
是清理项目的生命周期,它包含三个阶段
<1>. pre-clean执行一些清理前需要完成的工作
<2>. clean清理上一次构件生成的文件
<3>. post-clean执行一些清理后需要完成的工作
2. default生命周期
是项目构建时所需要执行的所有步骤,它是生命周期最核心的部分,它包含如下阶段
<1>. validate
<2>. initialize
<3>. generate-sources
<4>. process-source 处理项目主资源文件,一般来说,是对src/main/resource目录的内容进行变量替换等工作后,复制到项目输出的主classpath目录中
<5>. generate-resources
<6>. process-resources
<7>. compile编译项目的主源码,一般来说,是编译scr/main/java目录下的Java文件至项目输出的主classpath目录中
<8>. process-classes
<9>. generate-test-sources
<10>. process-test-sources 处理项目测试资源文件,一般来说,是对src/test/resources目录的内容进行变量替换等工作后,复制到项目输出的测试classpath目录中
<11>. generate-test-resources
<12>. process-test-resources
<13>. test-compile编译项目的测试代码。一般来说,是编译src/test/java目录下的Java文件至项目输出的测试classpath目录中
<14>. process-test-classes
<15>. test使用单元测试框架运行测试,测试代码不会被打包或部署
<16>. prepare-package
<17>. package 接受编译好的代码,打包成可发布的格式,如JAR,WAR
<18>. pre-integration-test
<19>. integration-test
<20>. post-integration-test
<21>. verify
<22>. install 将包安装到Maven本地仓库,供本地其他Maven项目使用
<23>. deploy 将最终的包复制到远程仓库,供其他开发人员和Maven项目使用。
3. site 生命周期
<1>. pre-site 执行一些在生成站点之前需要完成的工作
<2>. site 生成项目站点文档
<3>. post-size 执行一些在生成项目站点之后需要完成的工作
<4>. site-deploy 将生成的项目站点发布到服务器上
再次强调一下,Maven三套生命周期是项目独立的,而每一套独立的生命周期里面的一些阶段是有顺序执行,举例,如在命令行窗口执行命令: mvn clean 实际上是先执行pre-clean 在执行 clean 。