目录
Default (Build) 生命周期
命令行调用
Site 生命周期
如何清除本地 Maven 仓库并重新构建项目
Maven 构建配置文件
mvn dependency:purge-local-repository 这个命令是干什么的?
mvn clean install这个命令是干什么的?
配置文件激活
1、配置文件激活
前面的部分已经配置好了
Default (Build) 生命周期
生命周期阶段 | 描述 |
---|---|
validate(校验) | 校验项目是否正确并且所有必要的信息可以完成项目的构建过程。 |
initialize(初始化) | 初始化构建状态,比如设置属性值。 |
generate-sources(生成源代码) | 生成包含在编译阶段中的任何源代码。 |
process-sources(处理源代码) | 处理源代码,比如说,过滤任意值。 |
generate-resources(生成资源文件) | 生成将会包含在项目包中的资源文件。 |
process-resources (处理资源文件) | 复制和处理资源到目标目录,为打包阶段最好准备。 |
compile(编译) | 编译项目的源代码。 |
process-classes(处理类文件) | 处理编译生成的文件,比如说对Java class文件做字节码改善优化。 |
generate-test-sources(生成测试源代码) | 生成包含在编译阶段中的任何测试源代码。 |
process-test-sources(处理测试源代码) | 处理测试源代码,比如说,过滤任意值。 |
generate-test-resources(生成测试资源文件) | 为测试创建资源文件。 |
process-test-resources(处理测试资源文件) | 复制和处理测试资源到目标目录。 |
test-compile(编译测试源码) | 编译测试源代码到测试目标目录. |
process-test-classes(处理测试类文件) | 处理测试源码编译生成的文件。 |
test(测试) | 使用合适的单元测试框架运行测试(Juint是其中之一)。 |
prepare-package(准备打包) | 在实际打包之前,执行任何的必要的操作为打包做准备。 |
package(打包) | 将编译后的代码打包成可分发格式的文件,比如JAR、WAR或者EAR文件。 |
pre-integration-test(集成测试前) | 在执行集成测试前进行必要的动作。比如说,搭建需要的环境。 |
integration-test(集成测试) | 处理和部署项目到可以运行集成测试环境中。 |
post-integration-test(集成测试后) | 在执行集成测试完成后进行必要的动作。比如说,清理集成测试环境。 |
verify (验证) | 运行任意的检查来验证项目包有效且达到质量标准。 |
install(安装) | 安装项目包到本地仓库,这样项目包可以用作其他本地项目的依赖。 |
deploy(部署) | 将最终的项目包复制到远程仓库中与其他开发者和项目共享。 |
有一些与 Maven 生命周期相关的重要概念需要说明:
当一个阶段通过 Maven 命令调用时,例如 mvn compile,只有该阶段之前以及包括该阶段在内的所有阶段会被执行。
不同的 maven 目标将根据打包的类型(JAR / WAR / EAR),被绑定到不同的 Maven 生命周期阶段。
在下面的例子中,我们将 maven-antrun-plugin:run 目标添加到 Build 生命周期的一部分阶段中。这样我们可以显示生命周期的文本信息。
我们已经更新了 C:\MVN\project 目录下的 pom.xml 文件。
C:\CodeLife\MVN\project>mvn compile
Maven 将会开始处理并显示直到编译阶段的构建生命周期的各个阶段。
命令行调用
在开发环境中,使用下面的命令去构建、安装工程到本地仓库
mvn install
这个命令在执行 install 阶段前,按顺序执行了 default 生命周期的阶段 (validate,compile,package,等等),我们只需要调用最后一个阶段,如这里是 install。
在构建环境中,使用下面的调用来纯净地构建和部署项目到共享仓库中
mvn clean deploy
这行命令也可以用于多模块的情况下,即包含多个子项目的项目,Maven 会在每一个子项目执行 clean 命令,然后再执行 deploy 命令。
Site 生命周期
Maven Site 插件一般用来创建新的报告文档、部署站点等。
- pre-site:执行一些需要在生成站点文档之前完成的工作
- site:生成项目的站点文档
- post-site: 执行一些需要在生成站点文档之后完成的工作,并且为部署做准备
- site-deploy:将生成的站点文档部署到特定的服务器上
这里经常用到的是site阶段和site-deploy阶段,用以生成和发布Maven站点,这可是Maven相当强大的功能,Manager比较喜欢,文档及统计数据自动生成,很好看。 在下面的例子中,我们将 maven-antrun-plugin:run 目标添加到 Site 生命周期的所有阶段中。这样我们可以显示生命周期的所有文本信息。
我们已经更新了 C:\MVN\project 目录下的 pom.xml 文件。
C:\CodeLife\MVN\project>mvn site
Maven 将会开始处理并显示直到 site 阶段的 site 生命周期的各个阶段。
如何清除本地 Maven 仓库并重新构建项目
要清除本地 Maven 仓库并重新构建项目,可以按照以下步骤操作:
-
关闭当前使用 Maven 构建的项目。
-
打开命令行窗口(Windows 用户可以使用 cmd,Linux 或 macOS 用户可以使用终端),输入以下命令以删除本地 Maven 仓库中的所有依赖项和插件
mvn dependency:purge-local-repository
输入以下命令以重新构建项目:
mvn clean install
以上命令会从 Maven 仓库重新下载所有依赖项和插件,并重新编译并构建项目。
请注意,清除本地 Maven 仓库可能需要一些时间,具体时间取决于您的本地 Maven 仓库的大小以及您的 Internet 连接速度。此外,如果您使用的是 Maven 中央存储库(Maven Central Repository),则 Maven 服务器的负载也可能会影响下载速度。
Maven 构建配置文件
构建配置文件是一系列的配置项的值,可以用来设置或者覆盖 Maven 构建默认值。
使用构建配置文件,你可以为不同的环境,比如说生产环境(Production)和开发(Development)环境,定制构建方式。
配置文件在 pom.xml 文件中使用 activeProfiles 或者 profiles 元素指定,并且可以通过各种方式触发。配置文件在构建时修改 POM,并且用来给参数设定不同的目标环境(比如说,开发(Development)、测试(Testing)和生产环境(Production)中数据库服务器的地址)。
mvn dependency:purge-local-repository 这个命令是干什么的?
mvn dependency:purge-local-repository
是 Maven 的一个命令,用于清空本地仓库中的所有依赖。执行该命令后,Maven 会删除本地仓库中所有已经下载的依赖,强制重新从远程仓库下载依赖,并将它们安装到本地仓库。这个命令有时候可以用于解决 Maven 依赖问题,比如某些依赖无法下载或版本冲突等问题。需要注意的是,执行该命令会清空本地仓库的所有内容,因此建议在使用之前备份本地仓库的重要内容。
mvn clean install这个命令是干什么的?
mvn clean install
是一个Maven命令,用于在本地构建和安装项目。这个命令通常在一个项目的根目录下执行,它执行以下操作:
- 执行清理操作,删除先前构建的任何输出。
- 编译源代码。
- 运行单元测试并生成测试报告。
- 打包编译后的代码和依赖项成为JAR或WAR文件。
- 在本地Maven仓库中安装生成的库文件,以便可以在其他项目中使用该库。
这个命令是Maven构建过程中最常用的命令之一,它确保您始终使用最新的源代码构建您的项目,并在本地Maven仓库中安装您的库以供其他项目使用。
配置文件激活
Maven的构建配置文件可以通过多种方式激活。
- 使用命令控制台输入显式激活。
- 通过 maven 设置。
- 基于环境变量(用户或者系统变量)。
- 操作系统设置(比如说,Windows系列)。
- 文件的存在或者缺失。
1、配置文件激活
profile 可以让我们定义一系列的配置信息,然后指定其激活条件。这样我们就可以定义多个 profile,然后每个 profile 对应不同的激活条件和配置信息,从而达到不同环境使用不同配置信息的效果。
以下实例,我们将 maven-antrun-plugin:run 目标添加到测试阶段中。这样我们可以在不同的 profile 中输出文本信息。我们将使用 pom.xml 来定义不同的 profile,并在命令控制台中使用 maven 命令激活 profile。
pom.xml 文件如下:
mvn test -Ptest
mvn test
参考博客:
Maven 构建配置文件 | 菜鸟教程