tomcat内存溢出:PermGen space解决方法

时间:2022-04-04 12:08:26

最近集群服务器中的几台服务器在半夜自动重启tomcat后一段时间便都会报java.lang.OutOfMemoryError: PermGen space。

习惯性的百度,得到的答案基本上都是统一的解决办法:

手动设置MaxPermSize大小修改TOMCAT_HOME/bin/catalina.sh 在“echo "Using CATALINA_BASE: $CATALINA_BASE"”上面加入以下行: JAVA_OPTS="-server -XX:PermSize=64M -XX:MaxPermSize=128m

可是这段代码已经在TOMCAT_HOME/bin/catalina.sh添加进去了(如下图),它还是依旧报的这个错误

tomcat内存溢出:PermGen space解决方法

经过对比正常的服务器的配置和catalina.sh的配置,终于发现了问题:

从上图我们可以看到,

“echo "Using CATALINA_BASE: $CATALINA_BASE"

这一行,以及新加入的

JAVA_OPTS="$JAVA_OPTS -server -Xms1024m -Xmx1024m -XX:PermSize=10240m -XX:MaxPermSize=20480m"

这一行是在一个if语句里面,if语句上面有它的注释

# Bugzilla 37848: only output this if we have a TTY

所以说当没有TTY的时候if里面的语句是不会执行的,也就是说,问题可能就出现在这里。

通过ps aux|grep tomcat命令后发现TTY那一列输出的是?,也就是说没有TTY,后面也没有打印出自定义的内存大小的信息,所以很明显if里面的语句没有执行到,还是默认的大小,所以java.lang.OutOfMemoryError: PermGen space

tomcat内存溢出:PermGen space解决方法

tomcat内存溢出:PermGen space解决方法

所以把加大内存配置的代码放在其它地方,然后修改一下系统时间,让tomcat重启一下,再通过ps aux|grep tomcat命令查看,启动参数已经有了修改的内存配置...一段时间后,tomcat也没有溢出,问题应该是解决了...

tomcat内存溢出:PermGen space解决方法

tomcat内存溢出:PermGen space解决方法

Reference:

[1] //bbsmax.ikafan.com/static/L3Byb3h5L2h0dHAvYmxvZy5jc2RuLm5ldC91c2Vyd3loL2FydGljbGUvZGV0YWlscy80NDU2MzIzMw==.jpg