news 2026/5/21 13:26:33

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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 引入了全新的命名空间(http://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?欢迎在评论区留言,我们一起“对齐”一下!

相关地址:

  • Maven 发布记录:https://maven.apache.org/ref/
  • 迁移到 Maven4:https://maven.apache.org/guides/mini/guide-migration-to-mvn4.html
  • Maven4 介绍:https://maven.apache.org/whatsnewinmaven4.html
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 10:34:24

SDK游戏盾的工作原理具体是怎么完成防护的?

简单理解为三层的防护&#xff1a;玩家&#xff08;用户&#xff09; &#x1f51c; SDK &#x1f51c; 游戏盾节点 &#x1f51c; 源站服务器&#x1f7e0; 客户端SDK校验&#xff08;第一道防护机制&#xff09;&#x1f7e2;校验客户端完整性&#xff0c;防止修改或是模…

作者头像 李华
网站建设 2026/5/12 7:12:00

四足机器人场景应用发展蓝皮书(2025)

摘要&#xff1a;本文全面覆盖全球及中国四足机器人产业核心领域&#xff0c;聚焦 2025 年行业发展关键拐点&#xff0c;系统呈现产业发展综述、现状分析&#xff08;含国内外主要企业与研究机构、投融资动向、行业标准与政策环境、产业规模与市场格局&#xff09;、产业链生态…

作者头像 李华
网站建设 2026/5/16 9:03:26

5G矿山车载监控终端山河矿卡定位监控终端

5G智慧矿山监控终端——赋能矿山智能化转型&#xff0c;筑牢安全生产防线在矿山行业向“少人化、无人化”转型的关键阶段&#xff0c;安全生产与高效运营成为核心诉求。传统监控设备受限于通信带宽、时延及环境适应性&#xff0c;难以满足复杂矿山场景的实时管控需求。5G智慧矿…

作者头像 李华
网站建设 2026/5/21 0:56:28

全网最全继续教育AI论文写作软件TOP10:深度测评与推荐

全网最全继续教育AI论文写作软件TOP10&#xff1a;深度测评与推荐 2026年继续教育AI论文写作工具测评&#xff1a;为何值得关注 随着人工智能技术的不断进步&#xff0c;AI写作工具在学术领域的应用日益广泛。对于继续教育群体而言&#xff0c;如何高效完成论文写作、提升内容质…

作者头像 李华