一、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>

</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 

 

 

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