简介

JVM的参数有很多很多,根据我的统计JDK8中JVM的参数总共有1853个,正式的参数也有680个。

这么多参数带给我们的是对JVM的细粒度的控制,但是并不是所有的参数都需要我们自己去调节的,我们需要关注的是一些最常用的,对性能影响比较大的GC参数即可。

为了更好的让大家理解JDK8中 GC的调优的秘籍,这里特意准备了八张图。在本文的最后,还附带了一个总结的PDF all in one文档,大家把PDF下载回去,遇到问题就看两眼,不美吗?

分代垃圾回收器的内存结构

为了更好的提升GC的效率,现代的JVM都是采用的分代垃圾回收的策略(ZGC不是)。

java运行时内存可以分为JVM内存和非JVM内存。

JVM内存又可以分为堆内存和非堆内存。

堆内存大家都很熟悉了,YoungGen中的Eden,Survivor和OldGen。

非堆内存中存储的有thread Stack,Code Cache, NIO Direct Buffers,Metaspace等。

注意这里的Metaspace元空间是方法区在JDK8的实现,它是在本地内存中分配的。

JDK8中可用的GC

JDK8中到底有哪些可以使用的GC呢?

这里我们以HotSpot JVM为例,总共可以使用4大GC方式:

其中对于ParallelGC和CMS GC又可以对年轻代和老年代分别设置GC方式。

大家看到上图可能有一个疑问,Parallel scavenge和Parallel有什么区别呢?

其实这两个GC的算法是类似的,Parallel Scavenge收集器也经常称为“吞吐量优先”收集器,Parallel Scavenge收集器提供了两个参数用于精确控制吞吐量; -XX:MaxGCPauseMillis:控制最大垃圾收集停顿时间; -XX:GCTimeRatio:设置吞吐量大小。

同时Parallel Scavenge收集器能够配合自适应调节策略,把内存管理的调优任务交给虚拟机去完成。

JDK8中默认开启的是ParallelGC。

打印GC信息

如果想研究和理解GC的内部信息,GC信息打印是少不了的:

上图提供了一些非常有用的GC日志的控制参数。

内存调整参数

JVM分为Heap区和非Heap区,各个区又有更细的划分,下面就是调整各个区域大小的参数:

Thread配置

TLAB大家还记得吗?

如果一个对象的分配是在方法内部,并且没有多线程访问的情况下,那么这个对象其实可以看做是一个本地对象,这样的对象不管创建在哪里都只对本线程中的本方法可见,因此可以直接分配在栈空间中。

栈上分配的对象因为不用考虑同步,所以执行速度肯定会更加快速,这也是为什么JVM会引入栈上分配的原因。

上图就是TLAB的参数。

通用GC参数

虽然JDK8的GC这么多,但是他们有一些通用的GC参数:

这里讲解一下Young space tenuring,怎么翻译我不是很清楚,这个主要就是指Young space中的对象经过多少次GC之后会被提升到Old space中。

CMS GC

CMS全称是Concurrent mark sweep。是一个非常非常复杂的GC。

复杂到什么程度呢?光光是CMS调优的参数都有一百多个!

下图是常用的CMS的参数。

CMS这里就不多讲了,因为在JDK9之后,CMS就已经被废弃了。

主要原因是CMS太过复杂,如果要向下兼容需要巨大的工作量,然后就直接被废弃了。

在JDK9之后,默认的GC是G1。

G1参数

G1收集器是分代的和region化的,也就是整个堆内存被分为一系列大小相等的region。在启动时,JVM设置region的大小,根据堆大小的不同,region的大小可以在1MB到32MB之间变动,region的数量最多不超过2048个。Eden区、Survivor区、老年代是这些region的逻辑集合,它们并不是连续的。

G1中的垃圾收集过程:年轻代收集和混合收集交替进行,背后有全局的并发标记周期在进行。

当老年代分区占用的空间达到或超过初始阈值,就会触发并发标记周期。

下图是G1的调优参数:

特别推荐一个分享架构+算法的优质内容,还没关注的小伙伴,可以长按关注一下:长按订阅更多精彩▼如有收获,点个在看,诚挚感谢

八张图彻底了解JDK8 GC调优秘籍!相关推荐

  1. 八张图彻底了解JDK8 GC调优秘籍-附PDF下载

    文章目录 简介 分代垃圾回收器的内存结构 JDK8中可用的GC 打印GC信息 内存调整参数 Thread配置 通用GC参数 CMS GC G1参数 总结 简介 JVM的参数有很多很多,根据我的统计JD ...

  2. java导出pdf_一张PDF了解JDK11 GC调优秘籍-附PDF下载

    简介 JDK11相比JDK10,添加了一个新的Source-File Mode,可以直接通过java来运行单个java源文件,而不需要进行编译.同时还提供了新的HTTP API,支持响应性stream ...

  3. 一文了解JDK12 13 14 GC调优秘籍-附PDF下载

    文章目录 简介 那些好用的VM参数 G1的变化 配置FlightRecorder RAM参数 JDK13中的ZGC RTM支持 总结 简介 想了解JDK12,13,14中的GC调优秘籍吗?想知道这三个 ...

  4. 一张PDF了解JDK9 GC调优秘籍-附PDF下载

    文章目录 简介 Oracle中的文档 JDK9中JVM参数的变化 废弃的JVM选项 不推荐(Deprecated)的JVM选项 被删除的JVM参数 JDK9的新特性Application Class ...

  5. 一张PDF了解JDK10 GC调优秘籍-附PDF下载

    文章目录 简介 Java参数类型 Large Pages JIT调优 总结 简介 今天我们讲讲JDK10中的JVM GC调优参数,JDK10中JVM的参数总共有1957个,其中正式的参数有658个. ...

  6. DL之DNN之BP:神经网络算法简介之BP算法/GD算法之不需要额外任何文字,只需要八张图讲清楚BP类神经网络的工作原理

    DL之DNN之BP:神经网络算法简介之BP算法/GD算法之不需要额外任何文字,只需要八张图讲清楚BP类神经网络的工作原理 目录 BP类神经网络理解 1.信号正向传播FP 2.误差反向传播BP+GD B ...

  7. 大数据技术之_19_Spark学习_07_Spark 性能调优 + 数据倾斜调优 + 运行资源调优 + 程序开发调优 + Shuffle 调优 + GC 调优 + Spark 企业应用案例

    大数据技术之_19_Spark学习_07 第1章 Spark 性能优化 1.1 调优基本原则 1.1.1 基本概念和原则 1.1.2 性能监控方式 1.1.3 调优要点 1.2 数据倾斜优化 1.2. ...

  8. 一文看尽 JVM GC 调优

    一个著名的学习方法论 向橡皮鸭求助 学会提问,提问也是一门艺术 提问前,先投入自己的时间做好功课 发生了什么事情 问题的基本情况 你投入的研究和发现 能正确提出你的问题,你的问题差不多已经解决一半 深 ...

  9. java eden space_JVM GC调优一则–增大Eden Space提高性能

    缘起 线上有Tomcat升级到7.0.52版,然后有应用的JVM FullGC变频繁,在高峰期socket连接数,Cpu使用率都暴增. 思路 思路是Tomcat本身的代码应该是没有问题的,有问题的可能 ...

最新文章

  1. 参数注入:最简方法,直接注入
  2. #20071-[NOIP2020模拟赛B组Day6]礼物购买【二分】
  3. 数字三角形——递归、递推、记忆化搜索
  4. 从零实现一个3D目标检测算法(3):PointPillars主干网实现(持续更新中)
  5. springboot banner在线生成_用了自定义Banner后,SpringBoot瞬间变的高大上了...
  6. 【bzoj2929】[Poi1999]洞穴攀行 网络流最大流
  7. 分布式光伏融资难点分析
  8. Excel中如何引用 「文件名」、「sheet 页」的名字
  9. mysqldump简单解析
  10. 2019蓝桥杯C++B:等差数列(详解)
  11. python中round(x、2)是什么意思_python中round函数具体使用详解
  12. mac 当前位置打开终端
  13. powershell和cmd区别
  14. Rayson API 框架分析系列之3:RSON序列化格式
  15. 什么是生成艺术NFT,Art Blocks为什么能持续霸榜
  16. php+dns+缓存,清理电脑dns缓存方法
  17. 怎么免费提取PDF页面?
  18. 【django】图形验证码接口设计、后端逻辑、前端逻辑【15】
  19. 如何让孩子算20以内的加法更快
  20. 自用房屋租住管理系统

热门文章

  1. 使用C++实现单项选择题标准化考试系统设计
  2. 线段树 ---- D. Power Tree(离线dfs序+线段树维护树上多条路径和的技巧)
  3. BZOJ 2157 「国家集训队」旅游(树链剖分,线段树,边权转点权)【BZOJ计划】
  4. ICPC 2005 hangzhou Generator (UVA1358)KMP + 期望DP / 高斯消元
  5. 【学习笔记】超简单的多项式求指(含泰勒展开式、牛顿迭代完成证明)
  6. 【网络流24题】B、太空飞行计划问题(最大权闭合图转最小割、最小割方案输出)
  7. Markdown简单语法
  8. mysql分页关键词_数据库分页关键字
  9. php排序最新,PHP排序的几种方法,值得来看!
  10. enter对应的keycode_键盘对应数字-keycode值大全