使用Maven进行项目管理 1 - 基本概念

本文介绍Maven的基本概念,在下一篇博文 使用Maven进行项目管理 2 - 用Maven管理最简单的Java项目中,我们将应用Maven工具和Maven的构建思想管理一个最简单的Java项目。

什么是Maven

Maven的官方网站上是这样定义的

引用
At first glance Maven can appear to be many things, but in a nutshell Maven is an attempt to apply patterns to a project's build infrastructure in order to promote comprehension and productivity by providing a clear path in the use of best practices.


意思是乍一看Maven包含很多内容,但是本质上,Maven就是用于项目构建的一组模式。

从这个定义出发,什么是Maven可以总结为三点

  1. Maven是用于项目构建的: Maven的用途是项目构建,也就是用于管理编译/测试/发布/部署等一系列项目管理任务的。
  2. Maven的本质是一套项目构建模式: 这是Maven背后的方法论,这里的模式和编程语言中的设计模式有一些区别,可以理解为完成一件事情的方法,通常是指“Best Practice”,完成一件任务的最佳方法。
  3. Maven的表现是一套工具: 我们从Maven官方网站上下载的是Maven程序,这是Maven的表现形式,一个用于项目构建的程序。通过简单的Maven命令,即可按照Maven所推崇的项目构建模式进行工作。但是我们应该注意,熟悉工具是简单的,更重要的是理解其背后的方法论。

什么是POM

POM是Project Object Model的缩写,意思是项目对象模型,说白了就是一个描述项目信息的XML文件。比如我创建了一个项目,叫my-app,则my-app文件夹下有个pom.xml,就是这里的POM了。

Maven工具需要的所有信息均从该文件获取,该文件描述了很多信息,从项目的基本信息,例如项目名称、版本等,到项目依赖关系、插件配置,均通过该文件进行描述。

这里的pom.xml和我们创建一个README.txt放在项目根目录下并没有本质区别,但是POM提供了一种标准的、结构化的项目信息描述方式,并可以被Maven程序所使用。

插件 (Plugin)

Plugin指Maven插件,Maven本身可以认为是一个执行框架,即Maven本身并不具备任何实际的功能,所有的功能均通过插件来完成。

例如,我们通过Maven命令来创建一个新项目

mvn archetype:create -DgroupId=com.mycompany.app -DartifactId=my-app


这里的archetype即是插件名称,我们可以把插件看做是一组任务 (Goal) 的集合,例如archetype插件包含以下任务

  • archetype:create
  • archetype:generate
  • archetype:create-from-project
  • archetype:crawl

任务 (Goal)

Goal指Maven任务,即完成某个具体的工作。例如archetype:create就是任务名称,指从某个原型 (项目模版)创建一个新的项目。

阶段 (Phase)

我们在使用Maven时,如果要对项目打包,会使用以下命令

mvn package


这里package和archetype:create这样的形式有所不同。这里的package就是Maven中的阶段 (Phase)。在项目管理中,我们会经常提到编码阶段、测试阶段、部署阶段等等,对,Maven中阶段(Phase)的概念和这里是差不多的。

阶段(Phase)和任务(Goal)主要有两个区别

粒度不同

阶段(Phase)粒度更大,可以认为一个阶段(Phase)对应一组任务(Goal),例如mvn package会依序执行以下任务

  • resources:resources
  • compiler:compile
  • resources:testResources
  • compiler:testCompile
  • surefire:test
  • jar:jar

独立性不同

阶段(Phase)之间存在依赖关系,每一个阶段(Phase)都是生命周期中的一个环节,执行任何一个阶段(Phase)需要先执行其前置的阶段(Phase)。这点很好理解,就像我们不可能不经过编码阶段就进入测试阶段。而任务(Goal)是独立的,每个任务是可以单独执行的,与其他任务无关。

生命周期 (Lifecycle)

生命周期 (Lifecycle) 和软件开发的生命周期类似,在Maven中,生命周期 (Lifecycle)由一组有序的阶段 (Phase)构成。其中任何一个阶段(Phase)的执行,需要先执行其前置阶段。

小结

  • Maven是一套项目构建思想 + 实用程序构成
  • 通过项目对象模型(POM)描述项目元信息
  • Maven程序本身只是一套插件(Plugin)执行框架,具体功能通过插件(Plugin)完成,插件(Plugin)由一组任务(Goal)构成
  • Maven把项目构建过程看做一个生命周期(Lifecycle),生命周期由若干阶段(Phase)构成,阶段(Phase)必须顺序执行

猜你喜欢

转载自lincan.iteye.com/blog/599174
今日推荐