• 了解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

    可打印当前线程的信息

  • 相关阅读:
    react Table key值使用方式
    C# EF查询不同分组的第一条数据
    C# MVC PDFJS URL传参方式+文件流方式在线展示文档
    docker nginx配置写错,启动不了容器的解决方案
    网络编程之BIO和NIO
    网络编程之BIO和NIO
    IT职场心得感想
    我们希望能与各位快乐拼博的站长们一路前行
    UART, SPI详解
    创业精神
  • 原文地址:https://www.cnblogs.com/hanlinhu/p/9487049.html
Copyright © 2020-2023  润新知