Maven 的 pom 文件生命周期

Posted jwen1994

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Maven 的 pom 文件生命周期相关的知识,希望对你有一定的参考价值。

1. pom 文件

pom 代表项目对象模型,它是 Maven 中工作的基本组成单位。它是一个 XML 文件,始终保存在项目的基本目录中的 pom.xml 文件中。pom 包含的对象是使用 Maven 来构建的,pom.xml 文件包含了项目的各种配置信息,需要特别注意,每个项目都只有一个 pom.xml 文件。

pom 文件中有一些节点用来描述项目配置信息,比如:

1)project:工程的根标签

2)modelVersion:pom 模型版本,maven2和3只能为4.0.0

3)groupId:这是工程组的标识。它在一个组织或者项目中通常是唯一的。例如,一个银行组织 com.companyname.project-group 拥有所有的和银行相关的项目。

4)artifactId:这是工程的标识。它通常是工程的名称。例如,消费者银行。groupId 和 artifactId 一起定义了 artifact 在仓库中的位置

5)version:这是工程的版本号。在 artifact 的仓库中,它用来区分不同的版本

6)packaging:定义 Maven 项目的打包方式,有 JAR 、WAR 和 EAR 三种格式

最小 pom 文件应该拥有以下几个元素

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.xdclass</groupId>
    <artifactId>demo</artifactId>
    <version>1.0-SNAPSHOT</version>
</project>

每个 pom 文件都继承一个父 pom,父(Super)POM 是 Maven 默认的 POM。所有的 POM 都继承自一个父 POM(无论是否显式定义了这个父 POM)。父 POM 包含了一些可以被继承的默认设置。因此,当 Maven 发现需要下载 POM 中的 依赖时,它会到 Super POM 中配置的默认仓库 。

可以使用以下命令来查看 Super POM 默认配置:mvn help:effective-pom

技术图片

下面介绍 pom 文件中用来配置依赖信息的节点

1)pom 文件中 dependencies 节点用来引入依赖,一个 dependencies 节点里面可以有多个 dependency

<dependencies>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
    </dependency>
</dependencies>

2)pom 文件中 parent 节点用来引入父 pom 文件

<parent>
    <groupId>xd.class<groupId>   //父项目的组Id标识符
    <artifactId>demo-parent</artifactId>    //父项目的唯一标识符
    <relativePath>/</relativePath>    //Maven首先在当前项目中找父项目的pom,然后在文件系统的这个位置(relativePath),然后在本地仓库,再在远程仓库找。
    <version>1.0</version>    //父项目的版本
</parent>

3)pom 文件中 modules 节点用引入模块

有些 Maven 项目会做成多模块的,这个标签用于指定当前项目所包含的所有模块。之后对这个项目进行的 Maven 操作,会让所有子模块也进行相同操作。

<modules>
    <module>com-a</module>
    <module>com-b</module>
    <module>com-c</module>
</modules>

4)pom 文件中 properties 节点用于定义 pom 常量

<properties>
    <java.version>1.7</java.version>
</properties>

上面这个常量可以在 pom 文件的任意地方通过 $java.version 来引用。

5)pom 文件中 dependencyManagement 节点

应用场景:当我们的项目模块很多的时候,我们依赖包的管理就会出现很多问题,为了项目的正确运行,必须让所有的子项目使用依赖项的同一版本,确保应用的各个项目的依赖项和版本一致,才能保证测试的和发布的是相同的结果。

使用的好处:在父模块中定义后,子模块不会直接使用对应依赖,但是在使用相同依赖的时候可以不加版本号,这样的好处是,可以避免在每个使用的子项目中都声明一个版本号,这样想升级或者切换到另一个版本时,只需要在父类容器里更新,不需要任何一个子项目的修改

假设有一个父项目,三个子项目,父项目的 pom 文件如下

<dependencyManagement>
  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.2.0</version>
      <scope>test</scope>
    </dependency>
  </dependencies>
</dependencyManagement>

三个子项目的 pom 文件分别如下:注意三个子项目对应三个 pom 文件

子项目1:
<dependency>
  <groupId>junit</groupId>
  <artifactId>junit</artifactId>
</dependency>

子项目2:
<dependency>
  <groupId>junit</groupId>
  <artifactId>junit</artifactId>
</dependency>

子项目3:
<dependency>
  <groupId>junit</groupId>
  <artifactId>junit</artifactId>
  <version>5.0</version>
</dependency>

dependencyManagement  和 dependencies 的区别

1)dependencies 即使在子项目中不写该依赖项,那么子项目仍然会从父项目中继承该依赖项(全部继承)。也就是说:子项目没有用到这个依赖,也会引入这个依赖

2)dependencyManagement 里只是声明依赖,并不实现引入,因此子项目需要显示的声明需要用的依赖。如果不在子项目中声明依赖,是不会从父项目中继承下来的;只有在子项目中写了该依赖项,并且没有指定具体版本,才会从父项目中继承该项,并且 version 和 scope 都读取自父 pom;另外如果子项目中指定了版本号,那么会使用子项目中指定的 jar 版本。

 

2. Maven 的生命周期

Maven 的生命周期就是对所有的构建过程进行抽象和统一。包含了项目的清理、初始化、编译、测试、打包、集成测试、验证、部署和站点生成等几乎所有的构建步骤。

maven的三个构建生命周期:

1)clean 

  pre-clean 执行一些清理前需要完成的工作

  clean 清理上一次构建生成的文件

  post-clean 执行一些清理后需要完成的工作

2)default 

  validate:验证工程是否正确

  compile:编译项目的源代码

  test:使用合适的单元测试框架来测试已编译的源代码。

  package:把已编译的代码打包成可以发布的格式,比如jar或者war

  verify:运行所有检查,验证包是否有效

  install:安装到maven本地仓库

  deploy:部署到远程的仓库,使得其他开发者或者工程可以共享

3)site

 

3.常用的 Maven 基本命令

1)常用命令

  mvn package maven 打包
  mvn generate-sources 生成源代码
  mvn compile 编译
  mvn test-compile 编译测试代码
  mvn test 运行测试
  mvn verify 运行检查
  mvn clean 清理项目
  mvn install 安装项目到本地仓库
  mvn deploy 发布项目到远程仓库
  mvn dependency:tree 显示Maven依赖树
  mvn dependency:list 显示Maven依赖列表

2)常用参数

  -D 指定参数,如 -Dmaven.test.skip=true 跳过单元测试;
  -P 指定 Profile 配置,可以用于区分环境;


3)web相关命令

  mvn tomcat:run 启动tomcat
  mvn jetty:run 启动jetty
  mvn tomcat:deploy 运行打包部署

以上是关于Maven 的 pom 文件生命周期的主要内容,如果未能解决你的问题,请参考以下文章

Maven 构建生命周期

MAVEN简介之——pom.xml

Maven 使用了一个标准的目录结构和一个默认的构建生命周期。

Apache Maven:构建生命周期

Maven生命周期

Maven聚合模块与继承和Maven的生命周期