本人项目经验不是很多,所以经常会遇到各种各样的问题,身边又没有人可以问,所以只能通过自己不断的google或者百度解决问题,就像现在这样,前几天新上线的项目崩了,看一下报错,居然是:java.lang.OutOfmemoryError:PermGen Space,这个时候只能google了。要解决java.lang.OutOfmemoryError:PermGen Space,就需要了解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)那么就会产生此错误信息了。PermGen Space与存放类的实例的heap区不同,java中的垃圾回收器GC 不会在主程序运行期对 PermGen Space 进行清理。因此产生这个问题原因有:
1.如果我们的应用中有很多的class时,很可能就会出现PermGen space的错误;
2.如果我们的 tomcat 在重启的时候,不是使用的 ./bin/shutdown.bat 而是使用 kill -9 xxx 直接杀掉,这样的话,存在PermGen space 里面的内存不会被释放的,这样多长进行 kill 之后,就会导致系统的内存被渐渐耗完,直到最后 tomcat 报错。
解决办法是:
1手动设置PermGen Space的大小:
1.修改 TOMCAT_HOME/bin/catalina.bat文件
在echo "using CATALINA_BASE:$CATALINA_BASE"上面加入这一行内容:set JAVA_OPTS=%JAVA_OPTS% -server -XX:PermSize=128m -XX:MaxPermSize=512m
2.如果是 linux 环境,则修改 TOMCAT_HOME/bin/catalina.sh:JAVA_OPTS="$JAVA_OPTS" -server -XX:PermSize=128m -XX:MaxSize=512m
在关闭tomcat时使用shutdown.bat不使用kill -9