天天看点

java.lang.OutOfMemoryError:PermGen space的一种解决办法

Exception in thread "DefaultQuartzSchedulerThread" java.lang.OutOfMemoryError:PermGen space

Exception in thread "http-443-Processor24" java.lang.OutOfMemoryError:PermGen space

Exception in thread "http-443-Processor20" java.lang.OutOfMemoryError:PermGen space

Exception in thread "http-443-Processor22" java.lang.OutOfMemoryError: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的时候。

在TOMCAT_HOME/bin/catalina.sh中设置内存大小

JAVA_OPTS="-server -Xms512m -Xmx512m -XX:PermSize=64M -XX:MaxPermSize=128m -Djava.awt.headless=true "

若不设置jvm默认是4M大小

还有以下几种原因的可能

 1,使用了proxool,因为proxool内部包含了一个老版本的cglib.

 2, log4j,最好不用,只用common-logging

 3, 老版本的cglib,快点更新到最新版。

 4,更新到最新的hibernate3.2 3

但如果先前很长一段时间是好的,也没经过大的改动,突然某一天使用某个功能时出现这种内存溢出,很有可能是在tomcat应用下部署了多个项目。

如我遇到的情况:

是部署在linux下的tomcat项目

webapps下有一个ROOT目录,里面放了所有web的.jsp页面、.js文件、lib库(包括第三方库),还有所有的.class文件。

我由于备份过ROOT文件夹,在webapps下出了ROOT还多了一个ROOT.bak文件夹(里面的内容跟ROOT下的相同),原以为这个文件不会有什么影响,可是恰恰是这个文件夹,使tomcat启动时加载了双倍的库和class文件,并且从日志中发现它竟然使用了ROOT.bak下的资源。导致预览报表时页面就吃吃没有响应,然后报上面的内存溢出异常。我删除掉这个文件夹以后就恢复正常了。

继续阅读