标签:mem 需要 使用 新生代 ror 并且 tst uri 指定
最大堆空间
初始堆空间大小,如果初始堆空间耗尽,JVM会对堆空间扩容,其扩展上限为最大堆空间。通常-Xms与-Xmx设置为同样大小,避免扩容造成性能损耗。
设置新生代大小,设置一个较大的新生代会减少老年代的大小,新生代的大小一般设置为整个堆空间的1/3 或者1/4。
设置新生代中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=老年代/新生代
例如:-Xmx20m -Xms20M –XX:NewRatio=2 新生代大小为20MB*1/3=6MB ,老年代为13MB左右。
设置时应尽可能将对象预留在新生代,减少老年代GC的次数(FullGC)
设置垃圾最大年龄。如果设置为0的话,则年轻代对象不经过Survivor区,直接进入年老代。对于年老代比较多的应用,可以提高效率。如果将此值设置为一个较大值,则年轻代对象会在Survivor区进行多次复制,这样可以增加对象再年轻代的存活时间,增加在年轻代即被回收的概论。
令大于这个设置值的对象直接在老年代分配,避免在Eden区及两个Survivor区之间发生大量的内存复制。PretenureSizeThreshold参数只对Serial和ParNew两款收集器有效,Parallel
Scavenge收集器不认识这个参数,Parallel
Scavenge收集器一般并不需要设置。如果遇到必须使用此参数的场合,可以考虑ParNew加CMS的收集器组合。
当发生内存溢出时导出堆信息
-XX:+HeapDumpPath=/opt/OOM.dump
当发生内存溢出时导出堆信息指定输出的存放路径。
当发生内存溢出时可以执行指定脚本
如:
-XX:OnOutOfMemoryError=$JAVA_HOME/bin/Printstack
Printstackà $JAVA_HOME/bin/jstack –F %1 > /opt/stack
可打印当前线程的信息
标签:mem 需要 使用 新生代 ror 并且 tst uri 指定
原文地址:https://www.cnblogs.com/hanlinhu/p/9487049.html