Eclipse崩溃,错误提示:
MyEclipse has detected that less than 5% of the 64MB of Perm
Gen (Non-heap memory) space remains. It is strongly recommended
that you exit and restart MyEclipse with new virtual machine memory
paramters to increase this memory. Failure to do so can result in
data loss. The recommended Eclipse memory parameters are:
eclipse.exe -vmargs -Xms128M -Xmx512M -XX:PermSize=64M -XX:MaxPermSize=128M
1.参数的含义
-vmargs -Xms128M -Xmx512M -XX:PermSize=64M -XX:MaxPermSize=128M
-vmargs 说明后面是VM的参数,所以后面的其实都是JVM的参数了
-Xms128m JVM初始分配的堆内存
-Xmx512m JVM最大允许分配的堆内存,按需分配
-XX:PermSize=64M JVM初始分配的非堆内存
-XX:MaxPermSize=128M JVM最大允许分配的非堆内存,按需分配
我们首先了解一下JVM内存管理的机制,然后再解释每个参数代表的含义。
1)堆(Heap)和非堆(Non-heap)内存
按照官方的说法:“Java 虚拟机具有一个堆,堆是运行时数据区域,所有类实例和数组的内存均从此处分配。堆是在 Java 虚拟机启动时创建的。”“在JVM中堆之外的内存称为非堆内存(Non-heap memory)”。
可以看出JVM主要管理两种类型的内存:堆和非堆。简单来说堆就是Java代码可及的内存,是留给开发人员使用的;非堆就是JVM留给自己用的,
所以方法区、JVM内部处理或优化所需的内存(如JIT编译后的代码缓存)、每个类结构(如运行时常数池、字段和方法数据)以及方法和构造方法的代码都在非堆内存中。
堆内存分配
JVM初始分配的堆内存由-Xms指定,默认是物理内存的1/64;JVM最大分配的堆内存由-Xmx指定,默认是物理内存的1/4。默认空余堆内存小于40%时,JVM就会增大堆直到-Xmx的最大限制;
空余堆内存大于70%时,JVM会减少堆直到-Xms的最小限制。因此服务器一般设置-Xms、-Xmx 相等以避免在每次GC 后调整堆的大小。
说明:如果-Xmx 不指定或者指定偏小,应用可能会导致java.lang.OutOfMemory错误,此错误来自JVM,不是Throwable的,无法用try…catch捕捉。
非堆内存分配
JVM使用-XX:PermSize设置非堆内存初始值,默认是物理内存的1/64;由XX:MaxPermSize设置最大非堆内存的大小,默认是物理内存的1/4。(还有一说:MaxPermSize缺省值和-server -client选项相关,
-server选项下默认MaxPermSize为64m,-client选项下默认MaxPermSize为32m。这个我没有实验。)
上面错误信息中的PermGen space的全称是Permanent Generation space,是指内存的永久保存区域。还没有弄明白PermGen space是属于非堆内存,还是就是非堆内存,但至少是属于了。
XX:MaxPermSize设置过小会导致java.lang.OutOfMemoryError: PermGen space 就是内存益出。
说说为什么会内存益出:
(1)这一部分内存用于存放Class和Meta的信息,Class在被 Load的时候被放入PermGen space区域,它和存放Instance的Heap区域不同。
(2)GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,所以如果你的APP会LOAD很多CLASS 的话,就很可能出现PermGen space错误。
这种错误常见在web服务器对JSP进行pre compile的时候。
2)JVM内存限制(最大值)
首先JVM内存限制于实际的最大物理内存,假设物理内存无限大的话,JVM内存的最大值跟操作系统有很大的关系。简单的说就32位处理器虽然可控内存空间有4GB,但是具体的操作系统会给一个限制,
这个限制一般是2GB-3GB(一般来说Windows系统下为1.5G-2G,Linux系统下为2G-3G),而64bit以上的处理器就不会有限制了。
为何将上面的参数写入到eclipse.ini文件Eclipse没有执行对应的设置?
那为什么同样的参数在快捷方式或者命令行中有效而在eclipse.ini文件中是无效的呢?这是因为我们没有遵守eclipse.ini文件的设置规则:
参数形如“项 值”这种形式,中间有空格的需要换行书写,如果值中有空格的需要用双引号包括起来。比如我们使用-vm C:/Java/jre1.6.0/bin/javaw.exe参数设置虚拟机,
在eclipse.ini文件中要写成这样:
-vm
C:/Java/jre1.6.0/bin/javaw.exe
-vmargs
-Xms128M
-Xmx512M
-XX:PermSize=64M
-XX:MaxPermSize=128M
实际运行的结果可以通过Eclipse中“Help”-“About Eclipse SDK”窗口里面的“Configuration Details”按钮进行查看。
另外需要说明的是,Eclipse压缩包中自带的eclipse.ini文件内容是这样的:
-showsplash
org.eclipse.platform
–launcher.XXMaxPermSize
256m
-vmargs
-Xms40m
-Xmx256m
其中–launcher.XXMaxPermSize(注意最前面是两个连接线)跟-XX:MaxPermSize参数的含义基本是一样的,我觉得唯一的区别就是前者是eclipse.exe启动的时候设置的参数,
而后者是eclipse所使用的JVM中的参数。其实二者设置一个就可以了,所以这里可以把–launcher.XXMaxPermSize和下一行使用#注释掉。
其他的启动参数。 如果你有一个双核的CPU,也许可以尝试这个参数:
-XX:+UseParallelGC
让GC可以更快的执行。(只是JDK 5里对GC新增加的参数)
补充:
如果你的WEB APP下都用了大量的第三方jar,其大小超过了服务器jvm默认的大小,那么就会产生内存益出问题了。
解决方法: 设置MaxPermSize大小
可以在myelipse里选中相应的服务器比如tomcat5,展开里面的JDK子项页面,来增加服务器启动的JVM参数设置:
-Xms128m
-Xmx256m
-XX:PermSize=128M
-XX:MaxNewSize=256m
-XX:MaxPermSize=256m
或者手动设置MaxPermSize大小,比如tomcat,
修改TOMCAT_HOME/bin/catalina.bat,在echo “Using CATALINA_BASE: $CATALINA_BASE"上面加入以下行:
JAVA_OPTS=”-server -XX:PermSize=64M -XX:MaxPermSize=128m
建议:将相同的第三方jar文件移置到tomcat/shared/lib目录下,这样可以减少jar 文档重复占用内存
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