Maven插件(plugin)goal的执行与生命周期(lifecycle)phase的关系

这其实并非一个复杂的问题,可是彷佛没有什么资料对此作过清晰的说明,本文将对这个问题作一个详细的解释。

背景知识

maven对构建(build)的过程进行了抽象和定义,这个过程被称为构建的生命周期(lifecycle)。生命周期(lifecycle)由多个阶段(phase)组成,每一个阶段(phase)会挂接一到多个goal。goal是maven里定义任务的最小单元,至关于ant里的target。

以phase为目标构建

以phase为目标进行构建是最多见的,如咱们平时常常执行的mvn compile,mvn test,mvn package...等等,compile,test,package都是maven生命周期(lifecycle)里的phase,经过mvn命令,你能够指定一次构建执行到那一个阶段,在执行过程当中,全部经历的执行阶段(phase)上绑定的goal都将获得执行。例如,对于一个jar包应用,当执行mvn package命令时,maven从validate阶段一个阶段一个阶段的执行,在执行到compile阶段时,compiler插件的compile goal会被执行,由于这个goal是绑定在compile阶段(phase)上的。这一点可从其对应的mojo类上得知:

再好比常常使用的打包插件shade,它的goal是绑定到package阶段的,这样,使用mvn package进行打包时都会执行shade的。


以goal为目标构建

虽然以phase为目标的构建最多见,可是有时候咱们会发现, 一些插件的goal并不适合绑定到任何阶段(phase)上,或者是,这些goal每每是单独执行,不须要同某个阶段(phase)绑定在一块儿 ,好比hibernate插件的导入\导出goal多数状况下是根据须要要手动执行的(固然,也能够绑定到某个阶段上,好比进行单元测试时,可考虑将其绑定到test阶段上)。再好比jetty(6.1.26)插件,它的goal都是将打包或未打包的工程部署到jetty里而后启动jetty容器的,多数状况下,人们都是独立运行这些goal的,好比:人们但愿当键入mvn jetty:run后,工程就能完成编译后启动jetty,而jetty插件也确实是这样作的,它的run goal的mojo是这样声明的:

其中@execute phase="test-compile"指明jetty:run这一goal会促使maven先build到test-compile阶段,再执行这个goal.一样,对于jetty:run-war这个goal则要求先build到package阶段再执行该goal.

而另一个例子是exec插件的exec:java.

这个goal也声明了execute的phase,但倒是validate,这样,若是代码没有编译,执行这个goal就会出错,因此多数状况下,人们老是使用下面的方式执行的:
mvn clean compile exec:java
相关文章
相关标签/搜索