JVM内存调优常用参数

一、开始


查看当前JDK版本所支持的垃圾回收器有哪些、以及默认使用的回收器

java -XX:+PrintFlagsFinal -version | grep -E '<Use.*GC>'


JDK8和JDK11运行上述命令结果如下:

JVM内存调优常用参数
在这里插入图片描述


各种组合GC的开关

名称 描述
UseSerialGC 年轻代和老年代都用串行收集器
UseParNewGC 年轻代使用ParNew,老年代使用 Serial Old
UseParallelGC 年轻代使用Paraller Scavenge,老年代使用Serial Old
UseParallelOldGC 新生代Paraller Scavenge,老年代使用Paraller Old
UseConcMarkSweepGC 表示年轻代使用ParNew,老年代的用CMS + Serial Old
UseG1GC 使用G1垃圾回收器


  1. JDK8 默认是 Paraller Scavenge + Paraller Old ,JDK11默认是 G1 (其实JDK9开始默认是G1)。
  2. 在JDK11里面没有看到 ParNew,是因为 ParNew+Serial Old 这个组合已经不存在了。


注:

  1. 垃圾回收器和JDK的版本是有关系的,但目前主流的版本是8和11,所以此次学习也是用这两个版本
  2. 8和11默认的回收器分别是UseParallelGC和G1,既如此我们就深入理解它们
  3. 理解垃圾回收器无非是理论+各种参数,理论上篇已经解释了,此次就来看看这两款收集器的核心配置参数


二、常用命令


1、原生命令


注:pid 可以使用 jps/jcmd 查看

命令 描述 结果
jcmd pid VM.flags 查看当前JVM参数 JVM内存调优常用参数
jmap -heap pid 查看当前堆信息(JDK11用不了) JVM内存调优常用参数
jcmd pid GC.heap_info 查看各个区域内存使用情况,可以看Metaspace、和class space JVM内存调优常用参数
jstat -gc pid 查看内存使用情况、且可以看到GC频率 JVM内存调优常用参数


注:jstat -gc 结果描述

- `S0C`: 第一个幸存区(Survivor 0)的容量(Capacity)。
- `S1C`: 第二个幸存区(Survivor 1)的容量。
- `S0U`: 第一个幸存区的使用量(Used)。
- `S1U`: 第二个幸存区的使用量。
- `EC`: Eden 区的容量。
- `EU`: Eden 区的使用量。
- `OC`: 老年代的容量。
- `OU`: 老年代的使用量。
- `MC`: 元空间(Metaspace)的容量。
- `MU`: 元空间的使用量。
- `CCSC`: 压缩类空间的容量。
- `CCSU`: 压缩类空间的使用量。
- `YGC`: 年轻代垃圾回收的次数。
- `YGCT`: 年轻代垃圾回收的总时间。
- `FGC`: 老年代垃圾回收的次数。
- `FGCT`: 老年代垃圾回收的总时间。
- `CGC`: 全局垃圾回收的次数。
- `CGCT`: 全局垃圾回收的总时间。
- `GCT`: 所有垃圾回收的总时间。


2、arthas命令

命令 描述 图视
memory 查看内存使用情况 JVM内存调优常用参数


想了解arthas的小伙伴可以看这个:java线上问题排查工具——Arthas


三、Parallel


查看某个参数的值:jinfo -flag ParallelGCThreads pid

参数 描述
ParallelGCThreads 设置用于垃圾回收的线程数,通常设置为处理器数量的几倍。
MaxGCPauseMillis 设置期望的最大垃圾收集停顿时间,Parallel GC会尝试调整各种参数以满足这个目标。
GCTimeRatio 设置垃圾收集时间占总时间的比例。值为n,表示垃圾收集时间占总时间的1/(1+n)。比如19表示垃圾收集时间占总时间的1/20。
UseAdaptiveSizePolicy 当这个参数激活后,就不需要人工指定新生代的大小、Eden和Survivor区的比例、晋升老年代对象的大小,虚拟机会动态的调整。


四、G1 相关参数


查看某个参数的值:jinfo -flag G1HeapRegionSize pid

参数 描述 备注
G1HeapRegionSize 设置Region大小,并非最终值,会按照实际空间来看
MaxGCPauseMillis 设置G1收集过程目标时间,默认 200ms
G1NewSizePercent 新生代最小值 在我这个版本JDK没有这个参数
G1MaxNewSizePercent 新生代最大值,默认值60% 在我这个版本JDK没有这个参数
ParallelGCThreads STW期间,并行GC线程数
ConcGCThreads 并发标记阶段,并行执行的线程数
InitiatingHeapOccupancyPercent 设置触发标记周期的 Java 堆占用率阈值。默认值是45%。这里的java堆占比指的是non_young_capacity_bytes,包括old+humongous
JVM内存调优常用参数
在这里插入图片描述


五、通用参数


参数 描述
Xmx 设置JVM的最大堆内存大小。
Xms 设置JVM的初始堆内存大小。
Xmn 设置新生代的大小。新生代包含Eden区和两个Survivor区
Xss 设置每个线程的堆栈大小。
SurvivorRatio 设置Eden区与Survivor区的大小比例。
MaxPermSize / MaxMetaspaceSize 设置永久代(PermGen)或元空间(Metaspace)的最大大小。


六、JVM调优参数


所谓的JVM调优,就是为了保证我们系统的稳定运行

  1. 设置各个内存区域的大小和占比【五】
  2. 选定合适的垃圾回收器(基本都是用默认的)
  3. 当前系统关注的是快速回收还是吞吐量,基于此去设置 Parallel 和 G1的相关参数


原文始发于微信公众号(小道仙97):JVM内存调优常用参数

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/204566.html

(0)
java面试题的头像java面试题

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!