当前位置: 首页 > news >正文

maven 3.0多线程编译提高编译速度

mvn package 默认只使用 单线程 来执行构建生命周期(即顺序地构建每一个模块)。

如果你使用的是多模块项目,Maven 从 3.0 开始提供了**并行构建(parallel build)**的能力,但它不是默认开启的。

如何启用多线程构建?

你可以通过 -T 参数来启用并行构建。例如:

mvn -T 4 package

表示使用 4个线程 并行构建模块。

你也可以用下列方式配置:
• -T 1C:使用一个 CPU 核心
• -T 2C:使用两个 CPU 核心
• -T 0.5C:使用一半 CPU 核心

注意事项:
1. 并行构建只适用于模块之间无强依赖的情况(Maven 会自动分析依赖)。
2. 不建议对老版本插件或有副作用的插件使用并行构建,可能会造成问题。
3. 日志输出可能会变乱,建议加上 -B(batch 模式)或使用 --log-file 来写入日志文件。

如需查看当前 Maven 的并行配置,可执行:

mvn -version

会看到是否有 Multithreaded 相关信息。

命令 含义 示例(8 核 CPU)
-T 1 固定使用 1 个线程 1 线程
-T 4 固定使用 4 个线程 4 线程
-T 1C 每核 1 个线程 8 线程
-T 2C 每核 2 个线程 16 线程
-T 0.5C 每 2 核共用 1 线程 4 线程

常见错误

(Too many open files) 是一个典型的 操作系统限制错误,通常表示 Maven 或 Java 构建过程中打开的文件句柄数超过了系统允许的最大值。这在并发构建(比如你使用了 mvn -T 多线程)时尤其容易触发。

🔍 问题分析

背景

每个进程在 Linux/macOS 系统下都有一个最大“打开文件数限制”(file descriptor,简称 FD),当构建中打开了太多:
• .jar 文件
• 源代码文件
• class 文件
• 日志文件
• 依赖模块

等,就会触发这个错误。

✅ 解决方案

  1. 查看当前打开文件数限制
ulimit -n

一般默认值是 1024 或 256,远远不够。

  1. 临时提升当前 shell 的限制
ulimit -n 65535

然后再执行:

mvn -T 2C clean package

这个方法只对当前终端会话有效,重启 shell 会失效。

  1. 永久修改(macOS 示例)

macOS(zsh 或 bash 用户):

编辑 ~/.zshrc 或 ~/.bash_profile,添加:

ulimit -n 65535

然后运行:

source ~/.zshrc  # 或 source ~/.bash_profile

macOS 系统级(需要 root 权限):

sudo launchctl limit maxfiles 65535 65535

  1. 永久修改(Linux 示例)

修改 /etc/security/limits.conf

打开文件数限制(软限制和硬限制)

your_username soft nofile 65535
your_username hard nofile 65535

修改 /etc/pam.d/common-session(有些系统需要)

session required pam_limits.so

修改 /etc/systemd/user.conf 和 /etc/systemd/system.conf

DefaultLimitNOFILE=65535

然后重启机器或相关服务。

🧠 补充建议
• 如果你用的是 mvn -T 2C(使用 16 个线程),每个线程同时可能打开几十个文件,文件句柄很快就会用尽。
• 调整为 -T 1C 或 -T 4 也可能避免触发此问题,作为临时缓解。

http://www.xdnf.cn/news/625033.html

相关文章:

  • C++类型转换
  • Flink运行架构及并行度设置
  • 9.4在 VS Code 中配置 Maven
  • [C++]洛谷B3626 跳跃机器人(题干 + 详细讲解, BFS练习题)
  • 安卓11 不带谷歌包默认桌面布局
  • android studio 开启无线调试
  • JVM 的垃圾回收机制 GC
  • QT写槽函数的注意事项
  • 第1周 神经网络基石: 从零构建你的第一个模型
  • 深入理解设计模式之适配器模式
  • 类和对象(1)
  • ai陪伴项目——Android app开发
  • Spring框架--IOC技术
  • 国际前沿知识系列三:解决泛化能力不足问题
  • pytest+allure+allure-pytest 报告输出遇到的问题汇总
  • 计算机网络学习(五)——TCP
  • 【JVM 05-JVM内存结构之-堆】
  • 2025.5个人感悟
  • xdvipdfmx:fatal: File ended prematurely. No output PDF file written.
  • 企业批量处理刚需PrintPDF 网络财务办公打印 网页到 Office 一键转 PDF
  • 二十五、面向对象底层逻辑-SpringMVC九大组件之HandlerMapping接口设计
  • webpack中常见语句命令
  • 使用CodeBuddy实现网页自动连点器
  • OSPF ABR汇总路由
  • 网络层IP协议
  • 无法同步书签,火狐浏览器修改使用国内的账号服务器
  • 网络安全基础--第七课
  • [创业之路-375]:企业战略管理案例分析 - 华为科技巨擘的崛起:重构全球数字化底座的超级生命体
  • C++ 反向迭代器(Reverse Iterator)实现详解
  • MySQL:游标 cursor 句柄