项目中redeploy总是出现PermGen space的问题,于是上网查询,得到如下结论:
1. 什么是PermGen space:
PermGen space的全称是Permanent Generation space,是指内存的永久保存区域,这块内存主要是被JVM存放Class和metadata信息的,Class在被Loader时就会被放到PermGen space中,它和存放类实例(Instance)的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,所以如果你的应用中有很多CLASS的话,就很可能出现PermGen space错误。
2.常见情况:
2.1 如果你的WEB APP下都用了大量的第三方jar, 这些jar的class会被load(加载),其大小超过了jvm默认的大小(4M)那么就会产生此错误信息了。
2.2 在tomcat中redeploy时也会出现outofmemory的错误. 因为tomcat redeploy时,会重新加载class。原来的class metadata没有被释放掉(没有被GC回收),多次redeploy后,大小超出就会出现这样的问题。
===============
原来SUN 的JVM把内存分了不同的区,其中一个就是permenter区用来存放用得非常多的类和类描述。本来SUN设计的时候认为这个区域在JVM启动的时候就固定了,但他没有想到现在动态会用得这么广泛。而且这个区域有特殊的垃圾收回机制,现在的问题是动态加载类到这个区域后,gc根本没办法回收!
3. 解决办法:
解决方法1:
手动设置MaxPermSize大小,如果是linux系统,修改TOMCAT_HOME/bin/catalina.sh,如果是windows系统,修改TOMCAT_HOME/bin/catalina.bat, 在“echo "Using CATALINA_BASE: $CATALINA_BASE"”上面加入以下行: JAVA_OPTS="-server -XX:PermSize=64M -XX:MaxPermSize=128m 建议:将相同的第三方jar文件移置到tomcat/shared/lib目录下,这样可以达到减少jar 文档重复占用内存的目的。
解决方法2
修改eclipse.ini文件,修改如下:
-vmargs-Dosgi.requiredJavaVersion=1.5
-Xms128m-Xmx512m-XX:PermSize=64M-XX:MaxPermSize=128M
如果还报错,可以考虑如下修改
-vmargs-Dosgi.requiredJavaVersion=1.5
-Xms512m-Xmx1024m-XX:PermSize=256M-XX:MaxPermSize=512M
其他解决方案,可参考:http://blog.csdn.net/zenwong/article/details/2409775