Maven 4 终于快来了,新特性很香!

大家好,我是 Guide!在 Java 生态中,Maven 绝对是大家每天都要打交道的"老朋友"。

InterviewGuide 这个开源 AI 项目中,我使用了 Gradle。不过,根据大家的反馈来看还是更愿意使用 Maven 一些。

目前(2026 年 1 月)Maven 4.0 仍处于 Release Candidate 阶段,最新版本为 4.0.0-rc-5(2025 年 11 月 08 日发布),尚未正式 GA(General Availability)。

虽然目前 Maven 4 还处于 Release Candidate(RC)阶段,但它展现出来的特性足以让我们这些长期被 Maven 3 "历史债"折磨的开发者感到兴奋。

一句话总结:Maven 4 要求最低 Java 17 运行环境,通过分离构建与消费模型、树形生命周期等黑科技,彻底告别了臃肿且难以维护的 POM。

下面简单介绍一下 Maven 4 的最重要新特性(基于官方文档和发布记录):

Build POM 与 Consumer POM 的分离

这是 Maven 4 解决的最大痛点。在 Maven 3 时代,你发布的 pom.xml 既要管"怎么构建",又要管"别人怎么依赖",导致发布的元数据极其臃肿,甚至带有大量的 profile 和本地路径。

Maven 4 解决方案

  • Build POM :这就是你本地编辑的 pom.xml(模型升级至 4.1.0)。它包含所有的构建细节,比如插件配置、私有 profile 等。
  • Consumer POM :当你执行 deploy 时,Maven 4 会自动生成一个"纯净版"的 pom.xml(固定为 4.0.0 模型)。它去掉了所有插件、build 逻辑和 parent 继承关系,仅保留 GAV 坐标和核心依赖。

默认关闭 ,需显式开启:

ini 复制代码
mvn deploy -Dmaven.consumer.pom.flatten=true

或在项目根 .mvn/maven-user.properties 中永久配置:

ini 复制代码
maven.consumer.pom.flatten=true

这样的话,发布的 artifact 更干净,依赖解析更快,生态(Gradle、sbt、IDE、Sonatype 等)兼容性更好,无需再依赖 flatten-maven-plugin 等 hack 方案。

POM 模型升级到 4.1.0 + 多项简化语法

Maven 4 引入了全新的命名空间(**maven.apache.org/POM/4.1.0**...

1. 自动发现子项目

  • 新标签 <subprojects> :正式取代了容易产生术语混淆的 <modules>(标记为 deprecated)。
  • 隐式发现 :如果父项目 packaging=pom 且没有声明子项目,Maven 4 会自动扫描包含 pom.xml 的直接子目录。再也不用手动一行行写子模块名了!

2. 坐标推断(Inference)

<parent> 中,如果你按默认路径放置项目,可以省略 versiongroupId 甚至整个坐标。Maven 会自动从相对路径推断父 POM 坐标。

3. CI 友好变量原生支持

${revision}${sha1} 等变量现在是原生一等公民,不需要再写 hack 插件就能直接在命令行定义版本。

构建性能:从线性生命周期到树形并发

Maven 3 的生命周期是线性的,这意味着如果你的项目很大,构建过程就像"老牛拉破车"。

1. 树形生命周期与钩子

Maven 4 将生命周期升级为树形结构 ,并引入了 before:xxxafter:xxx 阶段。你可以更精准地在每个阶段前后绑定插件。

默认还是 Maven 3 时代的线性行为(向后兼容)。

要真正用上树形 + 更细粒度并发 ,必须显式加参数 -b concurrent(或 --builder concurrent)。

2. 并发构建器 (-b concurrent)

传统的并发构建往往受限于父子依赖。Maven 4 的并发构建器只要依赖模块进入 "Ready" 状态就会立即开跑,不再傻等父模块完成所有阶段。

开发者体验优化

1. 构建恢复 (-r / --resume)

大型项目构建到 90% 挂了?在 Maven 4 里直接 -r 即可从失败处继续,自动跳过已成功的模块。这简直是多模块项目的"救命稻草"。

2. 延迟发布 (deployAtEnd 默认开启)

为了防止出现"半成品"发布(一部分模块发了,另一部分报错没发),Maven 4 默认会在所有模块全部构建成功后才进行最后的统一发布。

3. 官方迁移助手 (mvnup)

担心升级出问题?官方直接给了 mvnup 工具,自动扫描并建议如何将你的 3.x 项目迁移到 4.1.0 模型。

现在该升级吗?

  • 生产环境 :由于目前还在 RC 阶段,且最低要求 Java 17,建议观望,等正式 GA 之后再小范围灰度。
  • 新项目/个人实验 :强烈建议开启 POM 4.1.0 进行尝试。特别是 Build/Consumer POM 的分离,能让你的项目元数据管理水平提升一个档次。
  • 大厂多模块项目:如果你深陷"Maven 构建慢、POM 维护难"的泥潭,Maven 4 的并发构建和自动子项目发现正是你需要的解药。

面对 Maven 二十年来最大的变动,你最期待哪个功能?或者你已经转向了 Gradle?欢迎在评论区留言,我们一起"对齐"一下!

相关地址:

相关推荐
开心就好20251 小时前
全面解析iOS应用代码混淆和加密加固方法与实践注意事项
后端
Thomas游戏开发2 小时前
分享一个好玩的:一次提示词让AI同时开发双引擎框架
前端·javascript·后端
龙门吹雪2 小时前
GO 语言处理多个布尔选项的实现方案
开发语言·后端·golang·布尔选项·标识位
毕设源码-钟学长2 小时前
【开题答辩全过程】以 基于Springboot vue肢体残疾人就业服务网站的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
源代码•宸2 小时前
Golang原理剖析(map面试与分析)
开发语言·后端·算法·面试·职场和发展·golang·map
WenJGo2 小时前
基于 IPIDEA 的 GitHub 代码文件抓取与数据可视化实践(Python 实现)
后端
上进小菜猪3 小时前
基于 YOLOv8 的高压输电线路(绝缘子、电缆)故障自动识别 [目标检测完整源码]
后端
白露与泡影3 小时前
Spring事件机制完全指南:解耦利器与实战
java·后端·spring