您的位置:首页 > 编程语言 > Java开发

java web中的Exception in thread ContainerBackgroundProcessor[StandardEngine[Catalina]]

2016-01-29 12:43 531 查看

java web中的Exception in thread "ContainerBackgroundProcessor[StandardEngine[Catalina]]" java.lang.OutOfMemoryError: PermGen space

最近老是在运行eclipse的时候,出现这样的问题:
1 Exception in thread "ContainerBackgroundProcessor[StandardEngine[Catalina]]" java.lang.OutOfMemoryError: PermGen space 2     at java.lang.ClassLoader.defineClass1(Native Method) 3     at java.lang.ClassLoader.defineClass(Unknown Source) 4     at java.security.SecureClassLoader.defineClass(Unknown Source) 5     at org.apache.catalina.loader.WebappClassLoader.findClassInternal(WebappClassLoader.java:2904) 6     at org.apache.catalina.loader.WebappClassLoader.findClass(WebappClassLoader.java:1173) 7     at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1681) 8     at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1559) 9     at com.opensymphony.xwork2.inject.ContainerImpl$5.create(ContainerImpl.java:311)10     at com.opensymphony.xwork2.inject.ContainerImpl$5.create(ContainerImpl.java:307)11     at com.opensymphony.xwork2.inject.util.ReferenceCache$CallableCreate.call(ReferenceCache.java:150)12     at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)13     at java.util.concurrent.FutureTask.run(Unknown Source)14     at com.opensymphony.xwork2.inject.util.ReferenceCache.internalCreate(ReferenceCache.java:76)15     at com.opensymphony.xwork2.inject.util.ReferenceCache.get(ReferenceCache.java:116)16     at com.opensymphony.xwork2.inject.ContainerImpl.getConstructor(ContainerImpl.java:603)17     at com.opensymphony.xwork2.inject.ContainerBuilder$5.create(ContainerBuilder.java:204)18     at com.opensymphony.xwork2.inject.Scope$2$1.create(Scope.java:51)19     at com.opensymphony.xwork2.inject.ContainerBuilder$3.create(ContainerBuilder.java:93)20     at com.opensymphony.xwork2.inject.ContainerBuilder$7.call(ContainerBuilder.java:487)21     at com.opensymphony.xwork2.inject.ContainerBuilder$7.call(ContainerBuilder.java:484)22     at com.opensymphony.xwork2.inject.ContainerImpl.callInContext(ContainerImpl.java:580)23     at com.opensymphony.xwork2.inject.ContainerBuilder.create(ContainerBuilder.java:484)24     at com.opensymphony.xwork2.config.impl.DefaultConfiguration.createBootstrapContainer(DefaultConfiguration.java:288)25     at com.opensymphony.xwork2.config.impl.DefaultConfiguration.reloadContainer(DefaultConfiguration.java:205)26     at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:66)27     at org.apache.struts2.dispatcher.Dispatcher.init_PreloadConfiguration(Dispatcher.java:390)28     at org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:437)29     at org.apache.struts2.dispatcher.ng.InitOperations.initDispatcher(InitOperations.java:74)30     at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.init(StrutsPrepareAndExecuteFilter.java:51)31     at org.apache.catalina.core.ApplicationFilterConfig.initFilter(ApplicationFilterConfig.java:277)32     at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:258)33     at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:382)

下面是图片形式:

原因:
1 /** 2      * 原因如下: 3      * PermGen space的全称是Permanent Generation space<br> 4      * 是指内存的永久保存区域,这块内存主要是被JVM存放Class和Meta信息的<br>
5      * Class在被Loader时就会被放到PermGen space中<br> 6      * 它和存放类实例(Instance)的Heap区域不同,GC(Garbage Collection)<br>
7      * 不会在主程序运行期对PermGen space进行清理,所以如果你的应用中有很多CLASS的话<br> 8      * 就很可能出现PermGen space错误,这种错误常见在web服务器对JSP进行pre compile的时候<br> 9      * 如果你的WEB APP下都用了大量的第三方jar, 其大小超过了jvm默认的大小(4M)那么就会产生此错误信息了<br>10      * 详细:http://greemranqq.iteye.com/blog/170586711      */

解决方法:
1 解决方法1:
2  3 手动设置MaxPermSize大小,如果是linux系统,修改TOMCAT_HOME/bin/catalina.sh,如果是windows系统,修改TOMCAT_HOME/bin/catalina.bat, 4 在“echo "Using CATALINA_BASE: $CATALINA_BASE"”上面加入以下行: 5 JAVA_OPTS="-server -XX:PermSize=64M -XX:MaxPermSize=128m 6  7 ///////////////////////////////////////////////////////////////////////// 8  9 解决方法2:
10 修改eclipse.ini文件,修改如下:11 12 -vmargs13 -Dosgi.requiredJavaVersion=1.514 -Xms128m15 -Xmx512m16 -XX:PermSize=64M
17 -XX:MaxPermSize=128M18 19 如果还报错,可以考虑如下修改20 21 -vmargs22 -Dosgi.requiredJavaVersion=1.523 -Xms512m24 -Xmx1024m25 -XX:PermSize=256M
26 -XX:MaxPermSize=512M

多数是采用第2中方法...修改了,就可以搞定啦....
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: