zoukankan      html  css  js  c++  java
  • 了解java虚拟机—堆相关参数设置(3)

    堆相关配置

    -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)

    图片.png

    -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

    可打印当前线程的信息

  • 相关阅读:
    2021年2月4号
    2021年2月3号
    2021年2月2号
    2021年2月1日
    2021年1月31日
    2021年1月30日
    20171205xlVBA往返航班组合
    选择文件
    从VBA过渡到Python
    20171114xlVba选定单行记录并打印
  • 原文地址:https://www.cnblogs.com/hanlinhu/p/9487049.html
Copyright © 2011-2022 走看看