`
juvenshun
  • 浏览: 1587566 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

Maven生命周期详解

阅读更多

Maven强大的一个重要的原因是它有一个十分完善的生命周期模型(lifecycle),这个生命周期可以从两方面来理解,第一,顾名思义,运行Maven的每个步骤都由它来定义的,这种预定义的默认行为使得我们使用Maven变得简单,相比而言,Ant的每个步骤都要你手工去定义。第二,这个模型是一种标准,在不同的项目中,使用Maven的接口是一样的,这样就不用去仔细理解每个项目的构建了,一般情况下,mvn clean install 这样的命令是通用的。我想,一定是吸收了许多项目的经验,Maven才能定义出如此完善的模型。

 

Maven有三套相互独立的生命周期,请注意这里说的是“三套”,而且“相互独立”,初学者容易将Maven的生命周期看成一个整体,其实不然。这三套生命周期分别是:

  • Clean Lifecycle 在进行真正的构建之前进行一些清理工作。
  • Default Lifecycle 构建的核心部分,编译,测试,打包,部署等等。
  • Site Lifecycle 生成项目报告,站点,发布站点。

我再次强调一下它们是相互独立的,你可以仅仅调用clean来清理工作目录,仅仅调用site来生成站点。当然你也可以直接运行 mvn clean install site 运行所有这三套生命周期。

 

知道了每套生命周期的大概用途和相互关系以后,来逐个详细看一下每套生命周期,Clean和Site相对比较简单,先解释一下。

 

每套生命周期都由一组阶段(Phase)组成,我们平时在命令行输入的命令总会对应于一个特定的阶段。比如,运行mvn clean ,这个的clean是Clean生命周期的一个阶段。有点绕?要知道有Clean生命周期,也有clean阶段。Clean生命周期一共包含了三个阶段:

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

mvn clean 中的clean就是上面的clean,在一个生命周期中,运行某个阶段的时候,它之前的所有阶段都会被运行,也就是说,mvn clean 等同于 mvn pre-clean clean ,如果我们运行 mvn post-clean ,那么 pre-clean,clean 都会被运行。这是Maven很重要的一个规则,可以大大简化命令行的输入。

 

下面看一下Site生命周期的各个阶段:

  • pre-site     执行一些需要在生成站点文档之前完成的工作
  • site    生成项目的站点文档
  • post-site     执行一些需要在生成站点文档之后完成的工作,并且为部署做准备
  • site-deploy     将生成的站点文档部署到特定的服务器上

这里经常用到的是site阶段和site-deploy阶段,用以生成和发布Maven站点,这可是Maven相当强大的功能,Manager比较喜欢,文档及统计数据自动生成,很好看。

 

最后,来看一下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     将最终的包复制到远程的仓库,以让其它开发人员与项目共享。

基本上,根据名称我们就能猜出每个阶段的用途,关于其它阶段的解释,请参考 http://maven.apache.org/guides/introduction/introduction-to-the-lifecycle.html

 

记住,运行任何一个阶段的时候,它前面的所有阶段都会被运行,这也就是为什么我们运行mvn install 的时候,代码会被编译,测试,打包。

 

此外,Maven的插件机制是完全依赖Maven的生命周期的,因此理解生命周期至关重要,在之后的文章里,我将会进一步解释Maven的插件机制。

54
3
分享到:
评论
16 楼 renzhigen12 2016-03-16  
15 楼 mpxsq 2015-11-05  
ycyangcai 写道
请问下:

maven绑定两个插件在相同生命周期的时候,如何配置这两个插件的执行的先后顺序


(Note: In Maven 2.0.5 and above, multiple goals bound to a phase are executed in the same order as they are declared in the POM, however multiple instances of the same plugin are not supported. Multiple instances of the same plugin are grouped to execute together and ordered in Maven 2.0.11 and above).
13 楼 ycyangcai 2015-03-10  
请问下:

maven绑定两个插件在相同生命周期的时候,如何配置这两个插件的执行的先后顺序
12 楼 lenki013 2014-12-22  
拜读了!
11 楼 changxianbest 2014-10-25  
写得很好!
10 楼 flywill2010 2013-12-13  
  讲的很明白,谢了
9 楼 huntfor 2013-11-30  
新手求问po主,mvn clean install,只执行从clean开始到install即: clean-> post-clean; validate -> install 还是分别执行两个生命周期。即 pre clean -> clean; 然后 validate -> install;按照博文所写,这三个生命周期是相互独立的,应该是后者。求po主证实
8 楼 Roger111 2013-11-17  
renlei413326889 写道
请教一下,为什么看到好多Maven的命令都是这种:mvn clean compile、mvn clean test、mvn clean install,都有clean选项,好像有时候也不需要clean的。有一点点迷惑,望能指点一下~

我觉得clean也算是一种习惯吧,它可以避免一些错误的发生。clean的主要功能是删除maven生成的target文件,如果不执行clean,而直接install的话,其过程中生成的如.class文件就会覆盖原来的文件,这在一般情况下是没有问题的。但是,比如你在源文件删除了一个java,结果没有clean,则它依然存在与target中,可能会对最终的结果造成影响。
7 楼 renlei413326889 2013-01-08  
请教一下,为什么看到好多Maven的命令都是这种:mvn clean compile、mvn clean test、mvn clean install,都有clean选项,好像有时候也不需要clean的。有一点点迷惑,望能指点一下~
6 楼 Wuaner 2012-10-22  
“在一个生命周期中,运行某个阶段的时候,它之前的所有阶段都会被运行,也就是说,mvn clean 等同于 mvn pre-clean clean ,如果我们运行 mvn post-clean ,那么 pre-clean,clean 都会被运行。这是Maven很重要的一个规则,可以大大简化命令行的输入。”。

楼主这句话点睛之笔!!!理解这个,我觉得才是理解maven中lifecycle & phase 的关键。

goal比较容易理解:goal是plugin的东西,是一个plugin中的Mojo文件(moji文件就是goal的定义文件,多由java文件或bellshell脚本编写)实现的特定目标。可以说:Mojo即goal。
goal也是可以单独调用的,调用的标准格式为:mvn groupId:artifactId:version:goal(如org.apache.maven.plugins:maven-compiler-plugin:2.5.1:compile)。在遵从了“约定优于配置“的前提后,这种对goal的直接调用的格式最终可以简化为:${prefix}:goal(如compiler:compile),其中${prefix}是artifactId的约定格式“maven-${prefix}-plugin”的中间部分。

最后,lifecycle的phase都和一个特定的goal相绑定,亦即,phase所提供的功能,其实是其所绑定的goal完成的。如 default lifecycle的compile这个phase,绑定的就是compiler:compile(maven-compiler-plugin插件的compile这个goal)。加上引用楼主的话,要强调的是:单独执行一个特定的goal,和单独执行一个与该goal绑定的某lifecycle的phase,过程及结果不见得是相同的,因为“在一个生命周期中,运行某个phase的时候,它之前的所有phase都会被运行”。
5 楼 zdnuist 2012-09-05  
不错学习了
4 楼 Finger_Zhou 2012-02-17  
老大的文章很是经典啊
3 楼 emilyzhanghong 2011-10-20  
很好的文章,学习了..
2 楼 alloyer 2009-07-02  
非常好的文章
1 楼 toopoo 2009-05-04  
讲的很全啊,支持

相关推荐

    Maven生命周期和及插件原理用法详解

    主要介绍了Maven生命周期和及插件原理用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值的相关资料

    Eclipse中maven的配置详解

    主要介绍了Eclipse中maven的配置详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

    Maven 配置文件 生命周期 常用命令详解

    Maven是围绕着构建生命周期的核心概念为原型,整个项目的创建和部署都是围绕着生命周期展开的,一个生命周期由若干个生命周期阶段组成。下面通过本文给大家介绍Maven 配置文件 生命周期 常用命令详解,一起看看吧

    Maven构建生命周期详细介绍

    主要介绍了Maven构建生命周期详细介绍,小编觉得还是挺不错的,这里分享给大家,需要的朋友可以参考下。

    maven window下安装包

    第7章:生命周期和插件/7.2 生命周期详解/7.2.3 default生命周期 第7章:生命周期和插件/7.2 生命周期详解/7.2.4 site生命周期 第7章:生命周期和插件/7.2 生命周期详解/7.2.5 命令行和声明周期 第7章:生命周期和...

    Maven聚合与继承实例详解.docx

    在javaweb高速发展的今天,我们软件设计人员往往会用很多种...Maven有很好的依赖管理系统(Dependency Management System)和项目生命周期的管理(Project Leftcycle),而其中的依赖管理是本文阐述和做出实例的重点。

    Maven 详解

    它为构建、测试、部署项目定义了一个标准的生命周期。提供了一个框架,允许遵循Maven标准的所有项目,方便的重用公用的构建逻辑。 Maven项目存在的Apache软件基金会,是一个开源社区,它开发的软件工具,基于一个...

    Maven权威指南 很精典的学习教程,比ANT更好用

    Maven生命周期 (Lifecycle) 3.5.3. Maven坐标 (Coordinates) 3.5.4. Maven仓库(Repositories) 3.5.5. Maven依赖管理 (Dependency Management) 3.5.6. 站点生成和报告 (Site Generation and Reporting) 3.6. ...

    maven 入门学习

    1、详细介绍了maven的基本元素使用以及所涉及到的配置。 2、对maven的生命周期和生效阶段进行详解。 3、对maven的仓库配置进行介绍。

    【2019版】Spring4.3入门视频课程

    bean生命周期、实例化bean的方式和时机、bean的作用域、继承配置 .自动装配、FactoryBean、两种后处理器 二、Spring AOP AOP简介、实现原理、代理技术 Spring AOP的配置实现 AspectJ表达式 三、Spring注解配置 注解...

    JAVA核心知识点整理(有效)

    1. 目录 1. 2. 目录 .........................................................................................................................................................1 JVM ........................

Global site tag (gtag.js) - Google Analytics