首页 > 代码库 > 4.Maven概念模型,maven的生命周期,Maven坐标,依赖管理(依赖范围,依赖声明),仓库管理,私服概念

4.Maven概念模型,maven的生命周期,Maven坐标,依赖管理(依赖范围,依赖声明),仓库管理,私服概念



1 maven概念模型

2 maven的生命周期,项目构建过程

Maven生命周期就是为了对所有的构建过程进行抽象和统一

包括项目清理,初始化,编译,打包,测试,部署等几乎所有构建步骤

 

Maven有“三套”相互独立的生命周期,而且相互独立,这三套生命周期分别是:

Maven三大生命周期

clean:清理项目的

在进行真正的构建之前进行一些清理工作。

default:构建项目的

构建的核心部分,编译,测试,打包,部署等等。

site:生成项目站点的

生成项目报告,站点,发布站点

要特别注意的是:它们是相互独立的,可以仅仅调用clean来清理工作目录,仅仅调用site来生成站点。当然也可以直接运行mvn clean install site 运行着三套生命周期。

 

clean生命周期每套生命周期都由一组阶段(Phase组成),我们平时在命令行输入的命令总会对应于一个特定的阶段。比如mvn clean,这个cleanClean生命周期的一个阶段。

clean生命周期

pre-clean

执行一些需要在clean之前完成的工作

clean

移除所有上一次构建生成的文件

post-clean

执行一些需要在clean之后立刻完成的工作

注意:

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

 

site生命周期

pre-site

执行需要生成站点文档之前完成的工作

site

生成项目的站点文档

post-site

执行一些需要生成站点文档之后完成的工作,并且为部署做准备

site-deploy

将生成的站点文档部署到特定的服务器上

注意:

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

 

Default生命周期是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

将最终的包赋值到远程的仓库,以让它开人员与项目共享。

注意:

运行任何一个阶段的时候,它前面的所有阶段都会被运行,这也就是为什么我们运行mvn install的时候,代码会被编译,测试,打包。此外,Maven的插件机制是完全依赖Maven的生命周期的,因此理解生命周期至关重要。

 




3 Maven坐标

Maven坐标主要组成

groupId :定义当前Maven项目隶属项目(习惯用包名来做)

例子:


artifactid:定义实际项目中的一个模板(一般是主类名)

version:定义当前项目的当前版本

packaging:定义该项目的打包方式(jar,war等方式)



4依赖管理(依赖范围,依赖声明)

依赖范围(scope

依赖声明

<dependencies>

                  <dependency>

                           <groupId>junit</groupId>

                           <artifactId>junit</artifactId>

                           <version>4.10</version>

                           <scope>test</scope>

                  </dependency>

</dependencies>

其中依赖范围scope用来控制依赖和编译,测试,运行的classpath的关系.主要的是三种依赖关系如下:

1.      compile:默认编译依赖范围。对于编译,测试,运行三种classpath都有效

2.      test:测试依赖范围。只对于测试classpath有效

3.      provided:已提供依赖范围。对于编译,测试的classpath都有效,但对于运行无效。因此由容器已经提供,例如servlet_api

4.      runtime:运行时提供。例如:jdbc驱动

 

传递性依赖:

 

见传递依赖图

 

传递性依赖影响范围

传递性依赖原则:

 

A-->B

A-->C

 

1.路径最近者优先

2.路径相同,第一声明者优先

 

注意:

1.dependencyManagement中定义的依赖子module不会共享

2.dependencies中定义的依赖子module可以共享

 

可选依赖不被传递

 

依赖优化:mvn dependency:list

5仓库管理,私服概念

何为Maven仓库

A用来统一存储所有Maven共享构建的位置就是仓库

Maven仓库布局

根据Maven坐标定义每个构建在仓库中唯一存储路径

大致为:groupId/artifactId/version/artifactId-version.packaging

仓库的分类:

本地仓库:

~/.m2/repository/

每个用户只有一个本地仓库

远程仓库

中央仓库:Maven默认的远程仓库

http://repo1.maven.org/maven2

私服:是一种特殊的远程仓库,它是架设在局域网内的仓库

镜像:用来替代中央仓库,速度一般比中央仓库块。

 

4.Maven概念模型,maven的生命周期,Maven坐标,依赖管理(依赖范围,依赖声明),仓库管理,私服概念