首页 > 代码库 > 【连载】Maven系列(三) 进阶
【连载】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
你还在等什么,赶快试试吧。
关注作者:
【连载】Maven系列(三) 进阶