【连载】Maven系列(三) 进阶

相关文章:

1.《用起来超爽的Maven——入门篇》

2.《用起来超爽的Maven——进阶篇》

一、Maven坐标:

Maven世界拥有大量须要构建jar文件,我们须要找一个用来唯一标识一个构建jar文件的统一规范。那么拥有了统一规范,就能够把查找工作交给电脑来完毕,从而自己主动下载jar文件到本地仓库。

Maven坐标是通过一些元素定义的,它们是groupId,artifactId,version,packaging,class-sifer

groupId:定义当前Maven项目隶属项目

artifactId:定义实际项目中的一个模块

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

packaging:定义该项目的打包方式当不定义packaging的时候。Maven 会使用默认值jar

classifier: 该元素用来帮助定义构建输出的一些附件

上面元素中经常使用的坐标是前面3个。如spring-beans的依赖

<dependency>

<groupId>org.springframework</groupId>

<artifactId>spring-bean</artifactId>

<version>3.0.5.RELEASE</version>

</dependency>

二、仓库

何为Maven仓库?

用来统一存储全部Maven共享构建jar文件的位置就是仓库

Maven仓库布局

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

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

仓库的分类

本地仓库:默认~/.m2/repository/

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

远程仓库

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

http://repo1.maven.org/maven2

镜像:用来替代中央仓库,下载速度一般比中央仓库快

maven加入镜像地址:改动~/.m2/settings.xml

<mirrors>

<mirror>

<id>ibiblio.org</id>

<mirrorOf>central</mirrorOf>

<name>ibiblio Mirror of http://repo1.maven.org/maven2/</name>

<url>http://mirrors.ibiblio.org/pub/mirrors/maven2</url>

</mirror>

<mirror>

<id>jboss-public-repository-group</id>

<mirrorOf>central</mirrorOf>

<name>JBoss Public Repository Group</name>

<url>http://repository.jboss.org/nexus/content/groups/public</url>

</mirror>

<mirror>

<id>nexus-osc</id>

<mirrorOf>*</mirrorOf>

<name>Nexus osc</name>

<url>http://maven.oschina.net/content/groups/public/</url>

</mirror>

</mirrors>

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

为什么要搭建nexus私服,原因非常easy。有些公司不提供外网给项目组人员。因此就不能使用maven訪问远程的仓库地址。所以非常有必要在局域网里找一台有外网权限的机器。搭建nexus私服,然后开发者连到这台私服上,这种话就能够通过这台搭建了nexus私服的电脑訪问maven的远程仓库。

三、生命周期

Maven强大的一个重要的原因是它有一个十分完好的生命周期模型

第一。执行Maven的每一个步骤都由它来定义的,这样的提前定义的默认行为使得我们使用Maven变得简单。相比而言。Ant的每一个步骤都要你手工去定义,会很麻烦。

第二,这个模型是一种标准。在不同的项目中,使用Maven的接口是一样的,这样就不用去细致理解每一个项目的构建了,普通情况下。mvn install这种命令是通用的。这就是依照契约编程的优点。

生命周期Maven有三套相互独立的生命周期,请注意这里说的是“三套”。并且“相互独立”,这三套生命周期各自是:

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

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

Site Lifecycle 生成项目报告,网站。公布网站。

再次强调一下它们是相互独立的。你能够只调用clean来清理工作文件夹。只调用site来生成网站。

当然你也能够直接执行 mvn clean install site 执行全部这三套生命周期。

clean生命周期每套生命周期都由一组阶段组成。我们平时在命令行输入的命令总会相应于一个特定的阶段。比方,执行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 将生成的网站文档部署到特定的server上

这里经经常使用到的是site阶段和site-deploy阶段,用以生成和公布Maven网站,这但是Maven相当强大的功能,Manager比較喜欢,文档及统计数据自己主动生成,非常好看。

Default生命周期Default生命周期是Maven生命周期中最重要的一个。绝大部分工作都发生在这个生命周期中。

这里。仅仅解释一些比較重要和经常使用的阶段:

validate 验证pom.xml

generate-sources 会依据pom配置去生成源码格式的包

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的生命周期的,因此理解生命周期至关重要。

四、经常使用的maven命令

mvn clean  清空target文件夹

mvn test   进行測试

mvn package 把maven项目打包成jar包或者war包

mvn package -Dmaven.test.skip=true  maven打包不运行測试用例的命令

mvn install 打包之后安装到本地仓库,然后其它项目能够引用

mvn eclipse:eclipse 生成eclipse项目管理文件

mvn idea:idea  生成idea项目管理文件

mvn site 生成项目站点文件夹

mvn jetty:run   执行项目于内嵌jettyserver

你还在等什么,赶快试试吧。

关注作者:

   

时间: 2024-10-01 02:26:34

【连载】Maven系列(三) 进阶的相关文章

Maven系列三 进阶

一.Maven坐标: Maven世界拥有大量需要构建jar文件,我们需要找一个用来唯一标识一个构建jar文件的统一规范:那么拥有了统一规范,就可以把查找工作交给电脑来完成,从而自动下载jar文件到本地仓库. Maven坐标是通过一些元素定义的,它们是groupId,artifactId,version,packaging,class-sifer groupId:定义当前Maven项目隶属项目 artifactId:定义实际项目中的一个模块 version:定义当前项目的当前版本 packagin

Maven 系列 三 :坐标和依赖

1 . 坐标 maven 的所有构件均通过坐标进行组织和管理.maven 的坐标通过 5 个元素进行定义,其中 groupId.artifactId.version 是必须的,packaging 是可选的(默认为jar),classifier 是不能直接定义的. groupId:定义当前 Maven 项目所属的实际项目,跟 Java 包名类似,通常与域名反向一一对应. artifactId:定义当前 Maven 项目的一个模块,默认情况下,Maven 生成的构件,其文件名会以 artifactI

Maven系列三Maven内置变量

Maven内置变量说明: ${basedir} 项目根目录(即pom.xml文件所在目录) ${project.build.directory} 构建目录,缺省为target目录 ${project.build.outputDirectory} 构建过程输出目录,缺省为target/classes ${project.build.finalName} 产出物名称,缺省为${project.artifactId}-${project.version} ${project.packaging} 打包

【连载】Maven系列(四)——配置私服

相关文章 1.<用起来超爽的Maven--入门篇> 2.<用起来超爽的Maven--进阶篇> 3.<Maven系列(三)   进阶> 一.为什么需要私服 有些公司并不提供外网给程序员,因此不能使用maven访问远程的仓库地址,所以很有必要在局域网里找一台有外网权限的机器:搭建nexus私服,然后程序员连到这台私服上,这样的话就可以通过这台搭建了nexus私服的电脑访问maven的远程仓库. 二.配置步骤 第一步:下载nexus-2.6.4-02.war包,然后拷贝到to

Spring Boot进阶系列三

Thymeleaf是官方推荐的显示引擎,这篇文章主要介绍怎么让spring boot整合Thymeleaf.  它是一个适用于Web和独立环境的现代服务器端Java模板引擎. Thymeleaf的主要目标是给开发工作流程带来优雅的自然模板 - 可以在浏览器中正确显示的HTML,也可以用作静态原型,从而在开发团队中实现更强大的协作.通过Spring Framework模块,与喜欢的工具的集成,Thymeleaf是HTML5 JVM Web开发的理想选择. 1.自然模板官方示例 用Thymeleaf

Spring Data 系列(三) Spring+JPA(spring-data-commons)

本章是Spring Data系列的第三篇.系列文章,重点不是讲解JPA语法,所以跑开了JPA的很多语法等,重点放在环境搭建,通过对比方式,快速体会Spring 对JPA的强大功能. 准备代码过程中,保持了每个例子的独立性,和简单性,准备的源码包,下载即可使用.如果,对JPA语法想深入研究的话,直接下载在此基础上进行测试. 前言 Spring Data 系列(一) 入门:简单介绍了原生态的SQL使用,以及JdbcTemplate的使用,在这里写SQL的活还需要自己准备. Spring Data 系

Apache Kafka系列(三) Java API使用

Apache Kafka系列(一) 起步 Apache Kafka系列(二) 命令行工具(CLI) Apache Kafka系列(三) Java API使用 摘要: Apache Kafka Java Client API 一.基本概念 Kafka集成了Producer/Consumer连接Broker的客户端工具,但是在消息处理方面,这两者主要用于服务端(Broker)的简单操作,如: 1.创建Topic 2.罗列出已存在的Topic 3.对已有Topic的Produce/Consume测试

Maven 系列 七 :Maven的生命周期和插件

一个完整的项目构建过程通常包括清理.编译.测试.打包.集成测试.验证.部署等步骤,Maven从中抽取了一套完善的.易扩展的生命周期.Maven的生命周期是抽象的,其中的具体任务都交由插件来完成.Maven为大多数构建任务编写并绑定了默认的插件,如针对编译的插件:maven-compiler-plugin.用户也可自行配置或编写插件. 1 . 三套生命周期 Maven定义了三套生命周期:clean.default.site,每个生命周期都包含了一些阶段(phase).三套生命周期相互独立,但各个生

Maven 系列 六 :将项目发布到私服

1 . 修改私服中仓库的部署策略 Release版本的项目应该发布到Releases仓库中,对应的,Snapshot版本应该发布到Snapshots仓库中.Maven根据pom.xml文件中版本号<version>节点的属性是否包含-SNAPSHOT,来判断该项目是否是snapshot版本.如果是snapshot版本,在执行mvn deploy部署命令时,maven会自动将项目发布到Snapshots仓库.要发布项目,首先需要将Releases仓库和Snapshots仓库的“Deploymen