我有一个Maven项目,它在Jenkins中构建了6个独立的Maven项目。我面临的问题是,在项目构建失败的时候会给出137错误代码:
错误:Maven JVM意外终止,退出代码为137
可以在控制台中使用相同的Maven目标成功构建项目,但在Jenkins中它失败了。通过重新启动Jenkins,可以解决问题。
我有一些静态数组列表。这些列表用于某些测试用例。这可能是内存泄漏吗?
我在构建服务器上遇到了相同的行为。错误是IMHO与maven内存设置(即MAVEN_OPTS
)无关,而是与底层(Linux)机器本身(Jenkins运行)的内存相关联。
(拒绝)Jenkins问题https://jenkins-ci.org/issue/12035提供了有关此问题的更多细节:
作为参考,状态代码137(128 + 9)通常意味着(可以在unix的风格之间有所不同)。通过接收信号终止该过程。在这种情况下,信号9是SIGKILL和unblockable kill。
如果是这种情况,底层机器/ OS需要更多虚拟内存。可以通过添加物理内存或交换空间来添加。
您应该尝试增加计算机的虚拟内存。
注意: 这也解释了为什么Jenkins重启(暂时)修复了这个问题。
我相信你应该增加内存设置的值 - 在Jenkins机器上的MAVEN_OPTS
,例如
MAVEN_OPTS=-Xmx1.5G -XX:MaxPermSize=0.7G
通过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 /等运行)。
进程被Linux OOM Killer杀死,因为你的机器资源很少。
通过jvm默认Xmx为机器提供更多内存和/或交换或减少进程的内存占用量,这很可能与jvm实际需要的内容相差甚远。
给它额外的java命令行选项
directly impacted
或配置系统变量
-Xmx256m -XX:MaxPermSize=512m
MaxPermSize对java 8+没用
我遇到了相同的错误代码。这个错误代码确实似乎与Jenkins环境中的JVM资源约束有关。我建议在错误发生后第二次重新运行构建,以查看是否可以获得额外/不同的输出,但这肯定取决于构建的哪个部分导致资源问题(在我的原因它是Maven下载)。
MAVEN_OPTS=-Xmx256m -XX:MaxPermSize=512m