常见的 JVM 调优方法有哪些?

常见的 JVM 调优方法有哪些?可以具体到调整哪个参数,调成什么值?

  • 对年轻代的Eden Survivor的比例进行配置

    • -XX:SurvivorRatio=8 :表示设置2个Survivor区:1个Eden区的大小比值为2:8,这意味着Survivor区占整个年轻代的1/5,这个参数默认为8
    • 如果经常性的 SurvivorTo放不下YGC的剩余的对象时候,可以适当的调整比例
  • 常用的CMS收集器: 设置回收阈值,需要根据程序的运行过程中的gc log来观察是否会用频繁的full gc 与 CMS gc

    • -XX:+UseConcMarkSweepGC 使用CMS收集器(ParNew + CMS +Serial Old)

    • -XX:CMSInitiatingOccupancyFraction=70 是指设定CMS在对内存占用率达到70%的时候开始GC。

    • -XX:+UseCMSInitiatingOccupancyOnly如果不指定, 只是用设定的回收阈值CMSInitiatingOccupancyFraction,则JVM仅在第一次使用设定值,后续则自动调整会导致上面的那个参数不起作用

    • Concurrent Mode Failure 错误:因为CMS给用户线程在 并发回收期间的预留内存不够,导致了这个错误,会使用Serial Old收集器,收集效率会急剧下降。

      • 所以说需要合理的设置上边的阈值
    • Promotion Failed:分配担保时,老年代的连续内存不足以存放年轻代晋升的对象,所以导致了这个错误(老年代内存碎片过多)

      • 解决:需要对内存碎片进行整理
        • -XX:UseCMSConpactAtFullCollection:开关默认开启,再要Full GC之前对内存碎片进行整理,停顿时间会变长
        • -XX:CMSFullGCsBeforeCompaction:默认0 每次full GC都会整理碎片。
        • 也可以适当的调整Survivor大小
  • -Xms20M:初始堆内存

  • -Xmx20M:最大堆内存

    • 默认空余堆内存小于40%时,JVM就会增大堆直到-Xmx的最大限制;空余堆内存大于70%时,JVM会减少堆直到 -Xms的最小限制。
      因此服务器一般设置-Xms、-Xmx相等以避免在每次GC 后调整堆的大小。对象的堆内存由称为垃圾回收器的自动内存管理系统回收。
  • -Xss128k

    • 表示可以设置虚拟机栈的大小为128k
  • -XX:PermSize=64M 指的是JVM初始非堆内存

  • -XX:MaxPermSize=64M 指的是JVM最大非堆内存

  • -XX:NewRatio=4:表示设置 年轻代(包括Eden和两个Survivor区)/老年代 的大小比值为1:4,这意味着年轻代占整个堆的1/5

    • Xms=Xmx并且设置了Xmn的情况下,该参数不需要进行设置。
    • -Xmn :年轻代大小,Sun官方推荐配置为整个堆的3/8
  • -Xmn20M:表示设置年轻代的大小为20M

  • -XX:MaxTenuringThreshold=15:对象每Minor GC在Survivor区存活一次 age++,当到age = 15的时候,直接进入老年代。

  • -XX:+PrintGCDetails打印GC日志

参考文章:https://cloud.tencent.com/developer/article/1198524

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JVM 调优是保证 Java 应用程序高性能运行的关键之一。以下是一些 JVM 调优的注意事项: 1. 观察 JVM 运行状态:使用 JVM 监控工具,例如 jstat、jconsole、jvisualvm 等,观察 JVM 的运行状态,包括内存使用情况、CPU 占用率、线程数等指标,以便及时发现问题并进行调整。 2. 调整堆内存大小:堆内存是 Java 程序最重要的内存区域,需要根据实际情况进行调整。一般情况下,可以通过设置 JVM 参数 -Xms 和 -Xmx 来调整初始堆大小和最大堆大小。 3. 选择合适的垃圾回收器:JVM 支持多种垃圾回收器,例如 Serial、Parallel、CMS、G1 等。不同的垃圾回收器具有不同的优缺点,需要根据实际情况进行选择。 4. 避免频繁 Full GC:Full GC 是一种比较耗时的垃圾回收操作,一般情况下应该尽量避免频繁触发。可以通过调整垃圾回收器的参数、优化代码实现等方式来避免频繁 Full GC。 5. 合理使用线程:线程是 Java 程序中的重要资源,需要根据实际情况进行合理的使用。过多的线程会占用过多的内存和 CPU 资源,导致程序性能下降,甚至引起死锁等问题。 6. 避免内存泄漏:内存泄漏是 Java 程序中常见的问题,会占用大量内存空间导致程序性能下降。需要及时发现并修复内存泄漏问题,例如使用工具进行内存泄漏检测、优化代码实现等方式。 7. 充分利用硬件资源:JVM 调优不仅仅是针对软件层面的优化,还需要充分利用硬件资源,例如使用 SSD 硬盘、增加 CPU 核数等方式来提高程序性能。 需要注意的是,JVM 调优是一个复杂的过程,需要根据具体的应用场景进行调整。同时,JVM 调优也需要进行充分测试和评估,以确保调整后的 JVM 能够稳定运行并提高程序性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值