当前位置: 首页>>技术教程>>正文


当Jenkins在Ubuntu上作为守护进程运行时,如何为Jenkins提供更多堆空间?

, , , ,

问题描述

我的Jenkins作业内存不足,在构建日志中提供了java.lang.OutOfMemoryError消息。但我使用Ubuntu软件包管理器,aptitudeapt-get来安装Jenkins,我不知道在哪里可以改变分配给Jenkins的堆空间量。

最佳解决方法

在Jenkins作业运行时,您可能会遇到两种类型的OutOfMemoryError消息:

  • java.lang.OutOfMemoryError: Heap space – 这意味着您需要在守护程序启动时增加分配给Jenkins的堆空间量。

  • java.lang.OutOfMemoryError: PermGen space – 这意味着您需要增加分配用于存储Java对象元数据的生成空间量。增加-Xmx参数的值不会影响此错误。

在Ubuntu 12.04 LTS上,取消注释/etc/default/jenkins第10行的JAVA_ARGS设置:

  • 要添加更多Java堆空间,请增加-Xmx Java参数的值。这设置了内存分配池(垃圾收集堆)的最大大小。

  • 要添加更多PermGen空间,请添加参数XX:MaxPermSize=512m(如果需要更多,请将512替换为其他内容。永久生成堆保存有关用户类的元信息。

例如,在全新安装Jenkins之后,此提取是来自默认的/etc/default/jenkins

# arguments to pass to java
#JAVA_ARGS="-Xmx256m"

如果将堆空间设置为1 GB,则会出现这种情况:

# arguments to pass to java
JAVA_ARGS="-Xmx1048m"

注意不要将堆大小设置得太大,因为你分配的内容会减少操作系统和其他程序可用的内存量,这可能会导致过多的分页(内存在RAM和交换盘之间来回交换,这将会减慢你的系统失败了)。

如果还设置了MaxPermSpace,则需要在参数之间添加空格):

# arguments to pass to java
JAVA_ARGS="-Xmx1048m -XX:MaxPermSize=512m"

进行更改后,从Jenkins Web界面正常重新启动Jenkins,或强制立即从命令行使用sudo /etc/init.d/jenkins restart重新启动。

我发现以下站点对于理解Java最大和永久生成堆大小很有用:http://www.freshblurbs.com/blog/2005/05/19/explaining-java-lang-outofmemoryerror-permgen-space.html

次佳解决方法

对于CentOS,默认情况下Jenkins.xml所在的目录是/etc /sysconfig /for jenkins-1.579-1.1

JENKINS_JAVA_OPTIONS="-Djava.awt.headless=true -Xmx -XX:MaxPermSize="

第三种解决方法

如果您使用的是Ubuntu Server,请先安装Monitoring插件,看看Jenkins正在使用多少内存。例如,这是我在安装后看到的:

java,ubuntu,jenkins,out-of-memory,heap

然后,使用命令free -m,我弄清楚服务器的内存大小是多少。就我而言,16Gb。有了这些信息,我打开了/etc/default/jenkins并更改了:


JAVA_ARGS="-Djava.awt.headless=true"


JAVA_ARGS="-Xmx8384m -Djava.awt.headless=true"

其中8384是8Gb。然后我使用命令sudo service jenkins restart重新启动Jenkins,然后,在触发了导致内存问题的作业后,事情看起来好多了,并且可以在此次和后续运行中完成作业:

java,ubuntu,jenkins,out-of-memory,heap

参考资料

本文由Ubuntu问答整理, 博文地址: https://ubuntuqa.com/article/6867.html,未经允许,请勿转载。