Apache Maven(二):构建生命周期

Maven 约定的目录结构

我要遵循Maven已经约定好的目录结构,才能让maven在自动构建过程中找到对应的资源进行构建处理。以下是maven约定的目录结构:

项目名称
|-- pom.xml				:Maven工程的核心配置文件
|-- src
    |-- main				:主程序
    |   |-- java			:JAVA源文件
    |   |-- resources			:框架或其他工具配置文件
    |-- test				:测试程序
        |-- java			:JAVA源文件
        |-- resources			:框架或其他工具配置文件

是我们只需要按照以上的目录结构进行存放文件,maven就可以自动找到对应文件进行构建处理。除了以上以下目录外,项目目录下可能还会存在README.txt,LICENSE.txt,.get,.svn,target等等目录或文件。

Maven 构建生命周期

Maven基于构建生命周期的核心概念。这意味着构建项目的过程已被明确定义。对于构建项目的人来说,这意味着只需要学习一小组命令和确保POM能得到想要的结果,就能构建任何Maven项目。

Maven有三种内置构建生命周期: default,clean 和 site。

  • default: 生命周期处理项目的部署(后面主讲部分);
  • clean : 生命周期清理项目;
  • site : 生命周期处理站点文档的创建

默认生命周期(项目部署)包含以下几个阶段:

  • validate: 验证项目是否正确,并提供所有有用的必要信息。
  • compile: 编译项目的源代码。
  • test: 使用合适的单元测试框架测试编译后的源代码。
  • package: 获取编译后的代码,并将其打包成可发布的格式,比如JAR。
  • verify: 对集成测试结果进行检查,以确保项目符合质量标准。
  • install: 将软件包安装到本地仓库中,用作本地其他项目的依赖项。
  • deploy: 在构建环境中完成,将最终包复制到远程仓库以与其它开发人员和项目共享。

这些生命周期阶段将按照顺序执行以完成默认的生命周期。这意味着当使用默认生命周期时,Maven先验证项目,然后编译源码,针对测试运行这些代码,打包成二进制文件(例如jar),运行集成测试包,验证集成测试,将经过验证的软件包安装到本地仓库,然后将骂安装软件部署到远程仓库,依次按照顺序执行。

在开发环境中,使用以下命令来构建项目并将其安装到本地仓库中:

mvn install

在执行 install 命令之前,此命令会按照默认生命周期阶段的执行顺序,先执行(validate、compile、package 等命令),只需按照默认周期的最后构建命令install,就可完成此周期。

在构建环境中,可以使用如下命令执行清理构建并且将项目部署到远程仓库中。

mvn clean deploy

同一个命令可用于多模块场景(即具有一个或多个子项目的项目)。Maven遍历每一个项目并执行clean,然后执行deploy(包括默认生命周期所有deploy之前的步骤)。

构建项目由插件目的组成

然而,尽管构建阶段负责构建生命周期的具体步骤,但是履行这些责任的方式可能会有所不同。这是通过声明插件目标绑定到这些构建阶段来完成的。

插件目标代表了一个特定的任务(比构建阶段更精细),有助于项目的构建和管理。它可以绑定到零或更多的构建阶段。不受任何构建阶段限制,可以通过直接调用在构建生命周期之外执行。执行顺序取决于调用目标和构建阶段的顺序,例如以下命令。该命令的clean 和 package 是构建阶段,而dependency:copy-dependencies 是一个插件目标。

mvn clean dependency:copy-dependencies package

如果执行此命令操作,则首先执行clean阶段(意味着执行clean生命周期之前的操作和clean本身),然后执行dependency:copy-dependencies 插件目标。最后执行package阶段(以及默认生命周期所有之前的阶段)。

通常用连字符(pre-*,post-* 或 process-*)命名的阶段不会直接从命令调用。这些阶段对构建进行排序,产生在构建之外无用的中间结果。

参考生命周期

以下列出了 default,clean 和 site 生命周期的所有构建阶段。它们按给定指定点的顺序执行。

  • clean 的生命周期:

    • pre-clean: 执行实际项目清理前所需要的流程。
    • clean: 删除以前版本生成的文件。
    • post-clean: 执行完成项目清理所需要的过程。
  • default 的生命周期:
    • validate: 验证项目是否正确,并提供所有必要的信息。
    • initialize: 初始化构建状态,例如设置属性或创建目录。
    • generate-sources: 生成包含在编译中的任何源代码。
    • process-sources: 处理源代码,例如过滤一些值。
    • generate-resources: 生成包含在包中的资源。
    • process-resources: 将资源复制并处理到目标目录中,准备打包。
    • compile: 编译项目的源代码。
    • process-classes: 处理从编译后生成的文件,例如在Java类上进行字节码增强。
    • generate-test-sources: 生成包含在编译中的一些测试源代码。
    • process-test-sources: 处理测试源代码,例如过滤一些值。
    • generate-test-resources: 创建测试资源文件。
    • process-test-resources: 将资源复制并处理到测试目标目录中。
    • test-compile: 将测试源代码编译到测试目标目录中。
    • process-test-classes: 从测试编译后处理生成的文件,例如在Java类上进行字节码增强
    • test: 使用合适的单元测试框架运行测试。这些测试不应该要求打包或部署代码。
    • prepare-package: 在实际打包之前执行一些必要的准备打包的操作。这通常会导致软件包的解压缩。
    • package: 接受编译的代码并将其打包为可发布的格式,例如JAR。
    • pre-integration-test: 在集成测试执行之前执行所需的操作。这可能涉及诸如设置所需环境等事情。
    • integration-test: 如果需要,可将程序包处理并部署到可运行集成测试的环境中。
    • post-integration-test: 执行集成测试后执行所需的操作。这可能包括清理环境。
    • verify: 运行一些检查来验证包是否有效并且符合质量标准。
    • install: 将软件包安装到本地存储库中,作为本地其他项目的依赖项。
    • deploy: 在集成或发行版环境中完成,将最终包复制到远程存储库,以便与其他开发人员和项目共享。
  • site 的生命周期:
    • pre-site: 执行实际项目站点生成之前所需的流程。
    • site: 生成项目的网站文档。
    • post-site: 执行完成网站生成所需的流程,并为网站部署做好准备。
    • site-deploy: 将生成的网站文档部署到指定的Web服务器。

原文地址:https://www.cnblogs.com/peter1018/p/9188520.html

时间: 2024-08-28 15:48:26

Apache Maven(二):构建生命周期的相关文章

Maven的构建生命周期理解

以下引用官方的生命周期解释https://maven.apache.org/guides/introduction/introduction-to-the-lifecycle.html: 一.构建生命周期基础: Maven基于构建生命周期的中心概念.这意味着构建和分发特定工件(项目)的过程被明确定义. 对于构建项目的人员,这意味着只需要学习一小堆命令即可构建任何Maven项目,POM将确保他们获得所需的结果. 有三个内置的生命周期:默认(default),清洁(clean)和站点(site).在

项目构建之maven篇:6.生命周期与插件

项目生命周期 清理 初始化 编译 测试 打包 部署 三套生命周期 1.clean pre-clean 执行一些需要在clean之前完成的工作 clean 移除所有上一次构建生成的文件 post-clean 执行一些需要在clean之后立刻完成的工作 2.compile validate generate-sources process-sources generate-resources process-resources 复制并处理资源文件,至目标目录,准备打包. compile 编译项目的源

4、maven——构建生命周期

什么是生命周期? 构建生命周期是一组阶段的序列(sequence of phase),每个阶段定义了目标被执行的顺序,这里的阶段就是生命周期的一部分. 一个典型的Maven生命周期由一些几个阶段的序列组成 当需要在某个特定的阶段之前或者是之后执行目标的时候,需要使用pre和post来定义这个目标. 当Maven开始构建工程,会按照所定义的阶段序列的顺序执行每个阶段注册的目标,Maven有一下三个标准的生命周期: clean default(or build) sit 目标 目标是一个特定的.对构

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

约定优于配置 当创建 Maven 工程时,Maven 会创建默认的工程结构.开发者只需要合理的放置文件,而在 pom.xml 中不再需要定义任何配置. Maven - POM POM 代表工程对象模型.它是使用 Maven 工作时的基本组建,是一个 xml 文件.它被放在工程根目录下,文件命名为 pom.xml. 它被放在工程根目录下 它被放在工程根目录下 它被放在工程根目录下 能够在 POM 中设置的一些配置如下: project dependencies plugins goals buil

Maven 构建生命周期

构建生命周期是什么? 构建生命周期阶段的目标是执行顺序是一个良好定义的序列.这里使用一个例子,一个典型的 Maven 构建生命周期是由下列顺序的阶段: 阶段 处理 描述 准备资源 资源复制 资源复制可以进行定制 编译 执行编译 源代码编译在此阶段完成 包装 打包 创建JAR/WAR包如在 pom.xml 中定义提及的包 安装 安装 这一阶段在本地/远程Maven仓库安装程序包 可用于注册必须执行一个特定的阶段之前或之后的目标,有之前处理和之后阶段.当 Maven 开始建立一个项目,它通过定义序列

深入理解maven构建生命周期和各种plugin插件

深入理解maven构建生命周期和各种plugin插件 本博文不会长篇大论的讨论生命周期的概念,而是从各种plugin的实际功能和应用出发,来讨论maven的实际应用,说得通透一点,生命周期(lifecycle)可以理解成由各种plugin按照一定的顺序执行来完成java项目清理.编译.打包.测试.布署等整个项目的流程的一个过程. 生命周期(lifecycle)由各个阶段组成,每个阶段由maven的插件plugin来执行完成.生命周期(lifecycle)主要包括clean.resources.c

Maven专题3——生命周期与插件

三套生命周期 Maven有3套相互独立的生命周期,用户可以调用某个生命周期的阶段,而不会对其他生命周期产生影响. 每个生命周期包含一些有先后顺序的阶段,后面的阶段依赖于前面的阶段,意味着用户调用后面的生命周期阶段时,同一生命周期中前面的阶段也将被执行. clean生命周期 pre-clean clean post-clean default生命周期 validate initialize generate-sources process-sources generate-resources pr

Maven的三大生命周期

一.Maven的三大生命周期 Maven的生命周期就是对所有的构建过程进行抽象和统一.包含了项目的清理.初始化.编译.测试.打包.集成测试.验证.部署和站点生成等几乎所有的构建步骤. Maven的生命周期是抽象的,即生命周期不做任何实际的工作,实际任务由插件完成,类似于设计模式中的模板方法. 二.三套生命周期 Maven由三套相互独立的生命周期,分别是clean.default和site.每个生命周期包括一些阶段(phase),阶段是有顺序的,后面的阶段依赖于前面的阶段. 1.clean生命周期

Gradle 庖丁解牛(构建生命周期核心托付对象创建源代码浅析)

[工匠若水 http://blog.csdn.net/yanbober 未经同意严禁转载,请尊重作者劳动成果.私信联系我] 1 背景 上一篇<Gradle 庖丁解牛(构建源头源代码浅析)>我们分析了 Gradle 框架自身初始化(非构建生命周期初始化)的核心流程,这一篇我们续着前面的分析继续(假设没看过前一篇的建议先去看前一篇,由于这一系列存在非常高的关联性).上一篇说到当我们运行 gradle taskName 命令后经过一系列艰难的框架初始化终于走到了 DefaultGradleLaunc