本文介绍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可以总结为三点
- Maven是用于项目构建的: Maven的用途是项目构建,也就是用于管理编译/测试/发布/部署等一系列项目管理任务的。
- Maven的本质是一套项目构建模式: 这是Maven背后的方法论,这里的模式和编程语言中的设计模式有一些区别,可以理解为完成一件事情的方法,通常是指“Best Practice”,完成一件任务的最佳方法。
- 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)必须顺序执行