set JAVA_OPTS=-Xms1300m -Xmx1300m -XX:PermSize=128M -XX:MaxNewSize=256m -XX:MaxPermSize=256m
jdk1.6最大使用内存大约是1600M多点,所以xmx加上XX:MaxPermSize不能超过1700M
最近发现如果仅设置set JAVA_OPTS=-Xms1300m -Xmx1300m或者小于1300M的话,tomcat频繁的当掉
在tomcat bin目录下发现类似hs_err_pid4808.log这样的文件
仔细查看的话可以发现类似这样的话
compacting perm gen total 35072K, used 34986K [0x60640000, 0x62880000, 0x64640000)
the space 35072K, 99% used
应该是permgen内存耗尽,通过设置
set JAVA_OPTS=-Xms1300m -Xmx1300m -XX:PermSize=128M -XX:MaxNewSize=256m -XX:MaxPermSize=256m
或者
set JAVA_OPTS=-Xms1600m -Xmx1600m
可以有效解决问题。
下面是在网上的关于PermGen space的分析
原因分析:
PermGen space的全称是Permanent Generation space,是指内存的永久保存区域,这块内存主要是被JVM存放Class和Meta信息的,Class在被Loader时就会被放到PermGen space中,它和存放类实例(Instance)的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,所以如果你的应用中有很CLASS的话,就很可能出现PermGen space错误,这种错误常见在web服务器对JSP进行pre compile的时候。如果你的WEB APP下都用了大量的第三方jar, 其大小超过了jvm默认的大小(4M)那么就会产生此错误信息了。