您的位置:首页 > 运维架构 > Tomcat

tomcat服务器“java.lang.OutOfMemoryError: PermGen space”问题

2014-03-24 13:30 405 查看
公司的网站经常会死掉,每次重启tomcat就会好用catalina错误日志如下: 

2013-4-19 3:27:41 org.apache.catalina.core.StandardContext listenerStart 
严重: Error configuring application listener of class com.sun.faces.config.ConfigureListener 
java.lang.OutOfMemoryError: PermGen space 
at java.lang.ClassLoader.defineClass1(Native Method) 
at java.lang.ClassLoader.defineClass(ClassLoader.java:621) 
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:124) 
at org.apache.catalina.loader.WebappClassLoader.findClassInternal(WebappClassLoader.java:1847)

解决方法:

先解释下什么是PermGen space 

PermGen space的全称是Permanent Generation space,是指内存的永久保存区域,这一部分用于存放Class和Meta的信息,Class在被 Load的时候被放入PermGen space区域,它和存放Instance的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,所以如果你的APP会LOAD很多CLASS的话,就很可能出现PermGen space错误。 

注意红色部分,如果加载的class太多就可能产生这个问题。 

我也曾经遇到过这种问题,并且在博客中写过: 

异常:java.lang.OutOfMemoryError: PermGen space 
http://yunzhu.iteye.com/blog/1035741 

我遇到的这个问题,引起的原因是自定义ClassLoader重复加载了很多次相同的jar,所以只要避免重复加载同样的jar就可以解决问题了。 

所以可能的原因有: 

加载了太多的class 

加载了太多的jar 

重复加载了太多的jar 

具体的解决方法: 

1. 手动设置MaxPermSize的大小 

修改 TOMCAT_HOME/bin/catalina.bat(Linux上为catalina.sh)文件, 

在echo "using CATALINA_BASE:$CATALINA_BASE"上面加入这一行内容: 

Java代码  



set JAVA_OPTS=%JAVA_OPTS% -server -XX:PermSize=128m -XX:MaxPermSize=512m  

catalina.sh修改如下: 

Java代码  



JAVA_OPTS="$JAVA_OPTS" -server -XX:PermSize=128m -XX:MaxSize=512m  

2.修改 TOMCAT_HOME/bin/catalina.bat文件的内容:在 %_EXECJAVA% %JAVA_OPTS% 后面添加: 
-Xms=256m -Xmx512m  
注意哦,前后有空格的 

例如:%_EXECJAVA% %JAVA_OPTS% -Xms=256m -Xmx512m(空格),后面的内容不变 

3. 可以考虑将相同的第三方jar文件拷贝到tomcat/shared/lib 目录下,这样可以减少jar文件重复占用内存的。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐