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

公司的网站经常会死掉,每次重启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代码   收藏代码
  1. set JAVA_OPTS=%JAVA_OPTS% -server -XX:PermSize=128m -XX:MaxPermSize=512m  


catalina.sh修改如下: 
Java代码   收藏代码
  1. 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文件重复占用内存的。

你可能感兴趣的:(web)