注册

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 坐标和核心依赖。


默认关闭 ,需显式开启:


mvn deploy -Dmaven.consumer.pom.flatten=true

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


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?欢迎在评论区留言,我们一起“对齐”一下!


相关地址:



作者:JavaGuide
来源:juejin.cn/post/7595527937832157238

0 个评论

要回复文章请先登录注册