Jenkins Maven构建137错误

问题描述 投票:33回答:5

我有一个Maven项目,它在Jenkins中构建了6个独立的Maven项目。我面临的问题是,在项目构建失败的时候会给出137错误代码:

错误:Maven JVM意外终止,退出代码为137

可以在控制台中使用相同的Maven目标成功构建项目,但在Jenkins中它失败了。通过重新启动Jenkins,可以解决问题。

我有一些静态数组列表。这些列表用于某些测试用例。这可能是内存泄漏吗?

java maven jenkins
5个回答
32
投票

我在构建服务器上遇到了相同的行为。错误是IMHO与maven内存设置(即MAVEN_OPTS)无关,而是与底层(Linux)机器本身(Jenkins运行)的内存相关联。

(拒绝)Jenkins问题https://jenkins-ci.org/issue/12035提供了有关此问题的更多细节:

作为参考,状态代码137(128 + 9)通常意味着(可以在unix的风格之间有所不同)。通过接收信号终止该过程。在这种情况下,信号9是SIGKILL和unblockable kill。

如果是这种情况,底层机器/ OS需要更多虚拟内存。可以通过添加物理内存或交换空间来添加。

您应该尝试增加计算机的虚拟内存。

注意: 这也解释了为什么Jenkins重启(暂时)修复了这个问题。


7
投票

我相信你应该增加内存设置的值 - 在Jenkins机器上的MAVEN_OPTS,例如

MAVEN_OPTS=-Xmx1.5G -XX:MaxPermSize=0.7G 

1
投票

通过Jenkins运行Maven时出现此错误:

ERROR: Maven JVM terminated unexpectedly with exit code 137

我意外地在MAVEN_OPTS参数中加了一个“和”:

-Xmx1024m and -Xms1024m

然后,我收到了这个错误:

Error: Could not find or load main class and
ERROR: Failed to launch Maven. Exit code - 1

之后,删除'和',我重申Jenkins并收到此错误:

java.lang.OutOfMemoryError: Java heap space

最后,我使用Global MAVEN_OPTS增加了内存:

-Xmx4096m -Xms4096m

这解决了这个问题。所以,这似乎与记忆有关。但是,它可能是与机器/ VM相关的问题(如上面所述的@boskoop)或容器问题(如果JVM通过Jenkins / Docker /等运行)。


1
投票

进程被Linux OOM Killer杀死,因为你的机器资源很少。

通过jvm默认Xmx为机器提供更多内存和/或交换或减少进程的内存占用量,这很可能与jvm实际需要的内容相差甚远。

给它额外的java命令行选项

directly impacted

或配置系统变量

-Xmx256m -XX:MaxPermSize=512m

MaxPermSize对java 8+没用


0
投票

我遇到了相同的错误代码。这个错误代码确实似乎与Jenkins环境中的JVM资源约束有关。我建议在错误发生后第二次重新运行构建,以查看是否可以获得额外/不同的输出,但这肯定取决于构建的哪个部分导致资源问题(在我的原因它是Maven下载)。

MAVEN_OPTS=-Xmx256m -XX:MaxPermSize=512m
© www.soinside.com 2019 - 2024. All rights reserved.