解决eclipse报PermGen space内存溢出异常的问题

时间:2023-01-21 14:24:50

2016.12.07补充说明:

很多开发的人员发生问题大都出现在重装eclipse 和 tomcat时,其实从官网下载下来的eclipse的基本配置(eclipse.ini)是基本可以满足jvm运行的,亲身经历也证明无论怎么配置eclipse.ini内存参数都无法解决PermGen space内存溢出的问题,后来发现内存的溢出不仅仅要针对eclipse做内存配置,还要对tomcat做配置,一般情况是在tomcat加载两个或两个以上的项目会出现异常。所以当你配置eclipse.ini无法解决问题时,请尝试如下配置看属否可以解决问题。

异常问题如下所示:

解决eclipse报PermGen space内存溢出异常的问题

1.点击Eclipse->Window->Preferences,如下所示:

解决eclipse报PermGen space内存溢出异常的问题

2.点击Server->Runtime Environments,选择Apache Tomcat v7.0,点击Edit按钮,如下图所示:

解决eclipse报PermGen space内存溢出异常的问题

3.选择运行的JRE,点击Installed JRES,如下图所示:

解决eclipse报PermGen space内存溢出异常的问题

4.选中jdk1.7.0_67,点击Edit,如下图所示:

解决eclipse报PermGen space内存溢出异常的问题

5.找到Default VM Arguments,在输入框中输入:-Xms512M -Xmx1024M  -XX:MaxPermSize=512m,然后finish->OK->OK。

解决eclipse报PermGen space内存溢出异常的问题

以下是网络转载内容(可供参考):

接下来说点理论的问题:内存溢出类型

1. java.lang.OutOfMemoryError: PermGen space

JVM管理两种类型的内存,堆和非堆。堆是给开发人员用的上面说的就是,是在JVM启动时创建;非堆是留给JVM自己用的,用来存放类的信息的。它和堆不同,运行期内GC不会释放空间。如果web app用了大量的第三方jar或者应用有太多的class文件而恰好MaxPermSize设置较小,超出了也会导致这块内存的占用过多造成溢出,或者tomcat热部署时侯不会清理前面加载的环境,只会将context更改为新部署的,非堆存的内容就会越来越多。

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)那么就会产生此错误信息了。

一个最佳的配置例子:(经过本人验证,自从用此配置之后,再未出现过tomcat死掉的情况)

set JAVA_OPTS=-Xms800m -Xmx800m -XX:PermSize=128M -XX:MaxNewSize=256m -XX:MaxPermSize=256m

2.java.lang.OutOfMemoryError: Java heap space

第一种情况是个补充,主要存在问题就是出现在这个情况中。其默认空间(即-Xms)是物理内存的1/64,最大空间(-Xmx)是物理内存的1/4。如果内存剩余不到40%,JVM就会增大堆到Xmx设置的值,内存剩余超过70%,JVM就会减小堆到Xms设置的值。所以服务器的Xmx和Xms设置一般应该设置相同避免每次GC后都要调整虚拟机堆的大小。假设物理内存无限大,那么JVM内存的最大值跟操作系统有关,一般32位机是1.5g到3g之间,而64位的就不会有限制了。

注意:如果Xms超过了Xmx值,或者堆最大值和非堆最大值的总和超过了物理内存或者操作系统的最大限制都会引起服务器启动不起来。

垃圾回收GC的角色

JVM调用GC的频度还是很高的,主要两种情况下进行垃圾回收:

当应用程序线程空闲;另一个是java内存堆不足时,会不断调用GC,若连续回收都解决不了内存堆不足的问题时,就会报out of memory错误。因为这个异常根据系统运行环境决定,所以无法预期它何时出现。

根据GC的机制,程序的运行会引起系统运行环境的变化,增加GC的触发机会。

为了避免这些问题,程序的设计和编写就应避免垃圾对象的内存占用和GC的开销。显示调用System.GC()只能建议JVM需要在内存中对垃圾对象进行回收,但不是必须马上回收,

一个是并不能解决内存资源耗空的局面,另外也会增加GC的消耗。

转自:http://www.cnblogs.com/longshiyVip/p/4533353.html