了解java虚拟机—堆相关参数设置(3)

时间:2022-12-27 12:56:59

堆相关配置

-Xmx

最大堆空间

-Xms

初始堆空间大小,如果初始堆空间耗尽,JVM会对堆空间扩容,其扩展上限为最大堆空间。通常-Xms与-Xmx设置为同样大小,避免扩容造成性能损耗。

-Xmn

设置新生代大小,设置一个较大的新生代会减少老年代的大小,新生代的大小一般设置为整个堆空间的1/3 或者1/4。

-XX:SurvivorRatio

设置新生代中eden空间和from/to空间的比例关系。

-XX:SurvivorRatio=eden/from=eden/to

例如:-Xmx20m -Xms20m –Xmn1m –XX:SurvivorRatio=2
新生代大小为512KB(eden)+256KB(from)+256KB(to)=1MB(Survivor),eden区为512KB总可用新生代为512KB(eden)+256KB(from或to)=768KB。(新生成的对象会分配在eden区,如果eden区占满后会触发YoungGC,将不可回收的对象放入from或to,并且年龄+1)

-XX:NewRatio

设置新生代和老年代的比例

-XX:NewRatio=老年代/新生代

例如:-Xmx20m -Xms20M –XX:NewRatio=2 新生代大小为20MB*1/3=6MB ,老年代为13MB左右。

设置时应尽可能将对象预留在新生代,减少老年代GC的次数(FullGC)

了解java虚拟机—堆相关参数设置(3)

-XX:MaxTenuringThreshold

设置垃圾最大年龄。如果设置为0的话,则年轻代对象不经过Survivor区,直接进入年老代。对于年老代比较多的应用,可以提高效率。如果将此值设置为一个较大值,则年轻代对象会在Survivor区进行多次复制,这样可以增加对象再年轻代的存活时间,增加在年轻代即被回收的概论。

-XX:PretenureSizeThreshold

令大于这个设置值的对象直接在老年代分配,避免在Eden区及两个Survivor区之间发生大量的内存复制。PretenureSizeThreshold参数只对Serial和ParNew两款收集器有效,Parallel
Scavenge收集器不认识这个参数,Parallel
Scavenge收集器一般并不需要设置。如果遇到必须使用此参数的场合,可以考虑ParNew加CMS的收集器组合。

-XX:+HeapDumpOnOutOfMemoryError

当发生内存溢出时导出堆信息

-XX:+HeapDumpPath

-XX:+HeapDumpPath=/opt/OOM.dump

当发生内存溢出时导出堆信息指定输出的存放路径。

-XX:OnOutOfMemoryError

当发生内存溢出时可以执行指定脚本

如:

-XX:OnOutOfMemoryError=$JAVA_HOME/bin/Printstack

Printstackà $JAVA_HOME/bin/jstack –F %1 > /opt/stack

可打印当前线程的信息