美文网首页
JDK1.8 垃圾回收及 jvm 参数配置

JDK1.8 垃圾回收及 jvm 参数配置

作者: 小蓝田 | 来源:发表于2023-03-02 09:38 被阅读0次

查看 java 进程垃圾回收情况
jstat -gcutil 28580 2s 5

  • 28580 表示进程号
  • 2s 表示每次打印时间间隔为 2 秒
  • 5 表示打印五次
jstat -gcutil 28580 2s 5
  • S0 S1 E O M 均表示各个空间使用百分比
  • S0 Survivor0区
  • S1 Survivor1区
  • E Eden区
  • O Old 区
  • M MetaSpace(原方法区)
  • YGC 新生代垃圾回收执行次数,edn 区空间不足时执行(执行频率比较高,因为大部分对象的存活寿命较短,在新生代里被回收,性能消耗小,耗时短)
  • YGCT 新生代垃圾回收总耗时
  • FGC 全堆范围进行垃圾回收次数,主要是 old 区或 metaspace区空间不足时执行(执行频率比较低,性能消耗大,耗时较长)
  • FGCT 全堆范围垃圾回收总耗时
  • GCT 垃圾回收总耗时

jstat -gc 28580 2s 5

  • 28580 表示进程号
  • 2s 表示每次打印时间间隔为 2 秒
  • 5 表示打印五次
jstat -gcutil 28580 2s 5
  • S0C S0 Capacity,即 S0 区实际空间容量大小
  • S0U S0 Used,即 S0 区实际使用空间大小,S0U/S0C=S0(第一个图中的 S0)
  • S1C S1U EC EU OC OU MC MU 以此类推
  • (S0C+S1C+EC+OC)/1024=MaxHeapSize
    (3072+3072+2091008+2097152)/1024=4096,即最大堆容量为 4096 兆
  • MC/1024=71640/1024=69.9,即 MetaSpace 容量大小为 69.9 兆
  • 此处看到的 MC 大小与 jvm 参数中设置的 -XX:MetaspaceSize 无关系,-XX:MetaspaceSize设置的是扩容阈值

jmap -heap 28580

jmap -heap 28580.png
  • From Space 和 To Space 对应的就是 S0、S1 区,两区交替变为 From 和 To
  • NewRatio 默认值是 2,即老年代:新生代=2:1,如果手动设置-Xmn-XX:NewSize-XX:MaxNewSize,则比例以手动设置为准
  • SurvivorRatio 默认值是 8,即 eden:survivor0:survivor1=8:1:1,但 jvm 中内存分配策略自适应功能默认是开启的,实际比例可能不是严格的 8:1:1,通过参数-XX:-UseAdaptiveSizePolicy可以关闭自适应,关闭后就是严格的 8:1

  • -Xms2048m 堆内存初始值(建议与 Xmx 设置一样的值)

  • -Xmx2048m 堆内存最大值

  • -Xmn1024m 新生代初始值(相当于对-XX:newSize、-XX:MaxnewSize同时设置)

  • -XX:NewSize=512m 新生代初始值(该值需要小于-Xms的值)

  • -XX:MaxNewSize=1024m 新生代最大值(该值需要小于-Xmx的值)

  • -XX:MetaspaceSize=256m 元空间(方法区)扩容阈值(-XX:PermSize jdk7)

  • -XX:MaxMetaspaceSize=256m 元空间最大值(-XX:MaxPermSize jdk7)

Metaspace实际分配的大小是随着需要逐步扩大的,每次扩大需要一次FGC,-XX:MetaspaceSize默认的值比较小,需要频繁GC扩充到需要的大小,为减少预热影响,可以将-XX:MetaspaceSize-XX:MaxMetaspaceSize指定成相同的值。

示例:
-Xms2048m -Xmx2048m -XX:MetaspaceSize=256m -XX:MaxMetaspaceSize=256m

-Xms2048m -Xmx2048m -Xmn1024m -XX:MetaspaceSize=256m -XX:MaxMetaspaceSize=256m

-Xms2048m -Xmx2048m -XX:NewSize=512m -XX:MaxNewSize=1024m -XX:MetaspaceSize=256m -XX:MaxMetaspaceSize=256m

推荐使用:
-Xms2048m -Xmx2048m -XX:MetaspaceSize=256m -XX:MaxMetaspaceSize=256m -XX:SurvivorRatio=8

相关文章

  • Java - JVM配置参数

    1.配置JVM 配置打印内存信息 运行打印出 2.各区参数 这是使用默认的垃圾回收器的参数,不同垃圾回收器回收策略...

  • jvm垃圾清理机制

    更多参考GC及JVM参数浅析JAVA的垃圾回收机制(GC)JVM系列三:JVM参数设置、分析jvm系列 (二) -...

  • jvm参数

    垃圾回收期 JVM参数说明

  • Java堆外内存回收方法

    [TOC] 一、JVM内存的分配及垃圾回收 JVM垃圾回收 由于JVM会替我们执行垃圾回收,因此开发者根本不需要关...

  • JVM 配置常用参数和常用 GC 调优策略

    JVM 配置常用参数 堆参数 回收器参数 项目中常用配置 常用组合堆参数堆参数回收器参数回收器参数项目中常用配置项...

  • jvm参数

    常用的JVM参数 跟踪JAVA虚拟机的垃圾回收 GC日志:jvm垃圾回收,记录jvm的运行状态,oom内存溢出的报...

  • 性能调优参数

    堆内存性能优化参数 垃圾回收性能优化参数 JVM服务参数调优实战 服务器配置:8 CPU,8G MEM,JDK 1...

  • 一文带你深入了解JVM性能调优以及对JVM调优的全面总结

    目录 JVM调优 概念 基本垃圾回收算法 垃圾回收面临的问题 分代垃圾回收详述1 分代垃圾回收详述2 典型配置举例...

  • 一文带你深入了解JVM性能调优以及对JVM调优的全面总结

    目录 JVM调优 概念 基本垃圾回收算法 垃圾回收面临的问题 分代垃圾回收详述1 分代垃圾回收详述2 典型配置举例...

  • JVM垃圾回收算法

    Java基础:JVM垃圾回收算法 [toc] 参考:Java基础:JVM垃圾回收算法图解JVM垃圾回收算法 总结:...

网友评论

      本文标题:JDK1.8 垃圾回收及 jvm 参数配置

      本文链接:https://www.haomeiwen.com/subject/ofilldtx.html