`
juvenshun
  • 浏览: 1595550 次
  • 性别: 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私服构建与插件开发1

    1. Maven生命周期详解: Maven生命周期是Maven管理项目构建过程的核心概念,它将构建过程划分为一系列有序的阶段(phase),使得开发者可以按需扩展或定制。生命周期包括三个主要部分:clean生命周期、default生命...

    Maven3实战笔记04Maven的生命周期和插件

    #### Maven生命周期概述 Maven是一个项目管理和综合工具,它通过一系列预定义的任务和明确的构建生命周期来管理项目的构建、报告和文档。Maven的核心特性之一是其生命周期(Lifecycle),它定义了一系列必须按顺序...

    黑马maven笔记,第一天

    #### Maven生命周期详解 Maven的生命周期是理解Maven工作方式的关键,主要有三个标准生命周期:`clean`、`default`和`site`。 - **`clean`生命周期**:负责清理项目,主要命令为`mvn clean`。 - **`default`生命...

    maven基本命令详解

    Maven 是一款非常强大的 Java 项目构建工具,它通过一系列的预定义生命周期和插件,简化了项目的构建、依赖管理和部署等工作。本文将对 Maven 的一些常用基本命令进行详细介绍。 #### 1. Maven 项目创建 在创建一...

    Maven学习 初学入门

    #### Maven生命周期详解 Maven的生命周期是一系列有序的阶段集合,每个阶段代表了构建过程中的一个特定动作,如编译源代码、运行测试、打包等。Maven的生命周期分为三类:Clean Lifecycle、Default Lifecycle、Site...

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

    Maven生命周期和插件原理用法详解 Maven生命周期是Maven项目构建的核心机制,它定义了项目从编译到部署的整个过程。Maven生命周期可以分为三大阶段:clean周期、default周期和site周期。 1. Clean周期:负责清理...

    Intellj构建和部署Maven Web项目详解

    - **生命周期管理**:Maven定义了一系列的生命周期,简化了构建过程中的命令和目标。 - **项目信息管理**:Maven提供了丰富的项目信息,如文档、报告、许可证等。 #### 二、使用IntelliJ IDEA创建Maven Web项目 1....

    Tedu5阶段maven的使用

    #### 二、Maven生命周期详解 - **Validate**:校验当前项目结构、环境是否符合Maven项目开发要求。 - **Compile**:Maven项目的编译,只负责main中的相关内容编译输出,默认输出到`target/classes`。 - **Test**:...

    SpringBoot学习0420.pdf

    #### 三、Maven 生命周期详解 Maven 生命周期包括多个阶段,每个阶段都对应特定的任务,例如清理、编译、打包、安装等。下面详细介绍几个关键命令: - **clean**: 清除项目的构建产物,即删除目标目录下的文件。 -...

    Eclipse中maven的配置详解

    在Eclipse中配置Maven是开发Java项目时必不可少的步骤,因为Maven作为一个强大的构建工具,可以帮助开发者管理和构建项目,依赖管理、构建生命周期以及插件系统都是其核心功能。下面我们将详细讲解如何在Eclipse中...

    maven与eclipse配置详解(含maven)

    Maven的生命周期和构建阶段是其核心概念。生命周期包括`clean`、`default`(或`compile`)、`verify`、`package`、`install`和`deploy`等阶段。每个阶段都有对应的默认目标,比如`compile`阶段用于编译源代码,`...

    java开发maven命令详解

    Maven是Java项目自动化构建工具的一个标准,它通过一组生命周期构建项目对象模型(POM),简化了构建过程。对于初学者来说,理解Maven的基本命令及其用法至关重要。 #### 1. `mvn -v` 用于显示当前使用的Maven版本...

    Maven 项目管理工具项目构建、依赖管理和项目生命周期管理

    Maven 项目生命周期是指一系列按照特定顺序执行的构建阶段。每个阶段都有其特定的目的,并且通常会执行一组预定义的任务。Maven 提供了三种标准生命周期: 1. **Clean Lifecycle(清理生命周期)** - `clean`:此...

    maven3.0.3及eclipse-maven3-plugin插件

    4. **支持Maven生命周期和构建过程**: 开发者可以在 Eclipse 中直接触发 Maven 生命周期的不同阶段,如编译、测试和打包,这极大地提高了开发效率。 5. **聚合项目的支持**: 对于包含多个子模块的 Maven 多模块...

    maven介绍及配置详解

    - **标准化构建过程:** Maven定义了一系列生命周期(LifeCycle)和构建阶段(Phase),这些生命周期和阶段是固定不变的。 - **依赖管理:** Maven提供了强大的依赖管理系统,能够自动下载和管理项目所需的JAR包等...

Global site tag (gtag.js) - Google Analytics