最近集群服务器中的几台服务器在半夜自动重启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添加进去了(如下图),它还是依旧报的这个错误
经过对比正常的服务器的配置和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重启一下,再通过ps aux|grep tomcat命令查看,启动参数已经有了修改的内存配置…一段时间后,tomcat也没有溢出,问题应该是解决了…