JVM基础原理篇-带你深入拆解G1垃圾回收原理

一、一统天下的G1垃圾回收器概述

大白话:

        1.整个堆空间,新生代和老年代比例大概为2:8;

        2.正常情况下,新生代回收是高频的,混合回收是频率是适中的,完全回收则是基本不会发生、频率低代价高的,一旦发生距离系统崩溃不远矣。

大白话:

        1.Eden区不够了,触发YGC;

        2.新生代中的对象不断地晋升(满15次)老年代,当老年代达到阈值,则先触发混合回收,将新生代和部分老年代进行垃圾回收;

        3.如果回收后,老年代对象仍不够用,则会触发完全回收(FullGC);

        4.多次FullGC失败后,抛出OOM。

二、图解G1垃圾回收器YGC的基本原理与执行过程

大白话:

        1.方法区(元空间)所关联的类、对象,方法区里的东西一般是常驻内存的;

        2.正在执行的线程关联的类、对象,是不会被标记清除的;

        3.跨代引用,老年代引用了新生代对象,这些新生代对象也是不会被清除的;

这些对象都是可以作为GC root起点的。

大白话:

        我们通过对CMS的执行过程理解,首先是初始标记、并发标记、预处理、重新标记、并发清理、重置线程,而G1在标记为存活对象后,就立刻移动该对象到S区。

大白话:

        动态调整新生代区域region的数量 - 在G1里,在执行YGC的时候,新生代的数量是可以动态变化的,一般什么都不设置的情况下,Eden区占比例在5%~60%之间(调整的原因,是根据每次执行垃圾回收后,根据当前的情况判断增加region数量,每增加一个region数量,Eden区就会增加一个,如果没有必要,Eden数量太多,导致回收时间太长,这时JVM就会减少Eden区数量)。

大白话:

        当区块被回收后,就会变成自由分区(或者叫空白分区),再有G1根据情况决定,这个区块下一步分变为Eden区还是别的区块。

大白话:

        在G1不断地YGC后,当某一次YGC判断老年代空间可能不太够用,则为下一次可能执行的混合回收做准备,提前开启并发标记,提高回收效率。

大白话:

        并行执行的任务,一般是重要的,且耗时短的。

大白话:

        1.释放分区 - 释放分区,类似我们的格式化硬盘,工作比较简单也比较快,涉及到一些全局状态表、全局集合的调整,所以采用串行的方式比较好。

三、【场景演示】通过GC日子理解YGC基本过程

大白话:

        young - YGC

        GC Workers - 8个工作线程

        Ext Root Scanning - GCRoots扫描

注意

        [Ext Root Scanning (ms):  0.4  0.6  0.2  0.2  0.2  0.1  0.2  0.1,从这里可以看出,不同的线程消耗的时间为什么会差异这么大,是因为不同的CPU的工作任务不同。

大白话: 

        total - G1堆总大小;

        used - 已使用堆大小;

        region size - 堆分区大小;

        28 young(28672k) - 年轻代分区有28个,总大小28672k;

        1 survivors(1024k) - S区1个,总大小1024k;

[Eden:9216.0K(9216.0K)垃圾回收之前占用空间大小 -> 0.0B垃圾回收之后占用空间大小(31.0M Eden区对占用空间大小 Survivors:0.0B -> 1024.0K Heap:9216.0K(128.0M) -> 848.1K(128.0M))]

再执行一次程序代码,发现

通过这两次对比,可以看出Eden区的堆空间大小被调整了,且Eden区的堆大小在5%~60%之间。

四、【原理精讲】停顿预测模型与垃圾区域选择原理

在启动参数中,增加一个 -XX:MaxGCPauseMillis=1 (最大停顿时间1,单位为1毫秒)

发现进行了多次GC,原因是每次GC都会尽量满足最大挺短时间,导出的后果就是每次垃圾会输的时间缩短了。

因为设置了最大停顿时间,导致GC时间内能处理的东西减少 ,从而JVM自动缩小了Eden区的堆大小。

大白话:

        最大停顿时间,设置过小,导致GC时间内能处理的东西减少 ,从而JVM自动缩小了Eden区的堆大小,设置过大,则导致在YGC的时候,S区放不下

大白话:

        根据垃圾对象占对象的比例排序,如果本次能清理3个region,就1/2/3一起清理,如果只能清理2个就清理1/2,如果 只能清理1个region,就只清理1号region,选出来的region,放到CSet中。

五、【原理精讲】深入理解混合回收工作原理与执行过程

因为并发标记阶段耗时非常长,有些对象是死的,被标记成了活动,有些对象是活的被标记成了死的。

大白话:

        这里就是前面讲到的,怎么统计每个region的垃圾笔记、以及region回收排序。

大白话:

        1.混合回收前面为什么会有一次YGC呢,前面讲了混合回收的触发条件是,在YGC后,已分配的内存占总内存的45%,触发混合回收;

        2.并发标记,标记的什么呢,主要标记的是老年代的对象。

大白话:

        为什么存活对象数量大于 85%的region就不再回收,这是因为前面讲了,一边标记一边复制,最耗时的是复制移动对象,所以一旦超过85%的region,就没有放入CSet的中回收的必要。

大白话:

        也就说,要执行混合有两个条件,第一个,在YGC后,已分配的内存占总内存的45%,触发混合回收,第二个就是可回收的空间占总空间的比例大于5%,才会启动混合回收。如果低于5%,JVM认为启动混合回收的意义不大,所以不启动混合回收。

五、【场景演示】通过GC日志理解混合回收工作过程

将for循环改为500次:

通过检查GC日志,发现这一个YGC跟前面的YGC已经有了明显的区别,多做了一步初始标记操作,那么后面离它不远,就会有混合回收日志。

这里已经开始并发标记

开始混合回收

这一行表示,老年代空间已经不够使用,G1通过把新生代快速转为老年代,供老年代使用,出现这一行,表示离FullGC不远矣。

触发了2次FullGC

在FullGC后,又是YGC,说明暂时把系统救回来了

到最后,FullGC已经解决不了问题了,最终OOM了。

六、【原理精讲】深入理解FullGC工作原理与执行过程

大白话:

        FullGC执行时间非常长,大概2-3秒,如果执行一次仍然不够,会再次执行,第二次回收软引用,如果还不够用,对象仍然无法分配,系统基本上就要OOM了,所以FullGC是非常危险的,当出现FullGC,我们就应该进行检查,防止更大的风险发生。

大白话:

        标记活跃对象,是所有垃圾回收期的回收的前提。

七、【故障实战】大对象导致视频无法观看故障实战

大白话:

        经验证,G1采用的是第二种思路(即使用多个region)存放大对象。

        但是有个基本原则,大对象尽量不要放入老年代,因为老年代region是有数量限制的(默认2048个),如果存放大量大对象,会把老年代占满,一旦占满应用会非常容易崩掉。

问题:

        现在的手机拍摄的视频一般都几百兆甚至几个G。

大白话:

        手动加大region大小,这个时候,大对象就不会被视为大对象,也就不会直接放入老年代region。

在前边的代码里,增加设置-XX:G1HeapRegionSize=8M,加入region大小。同时将代码中的byte1024改为1022,让数据的大小变小,可以看到执行的是YGC。

八、为什么sublist会导致系统OOM?

原因:

        subList所在的大对象,只要一直有在被引用,就一直不会被回收,而其本身占用的堆内存也一直不会释放,所以不推荐使用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/580856.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Unity之DOTweenPath轨迹移动

Unity之DOTweenPath轨迹移动 一、介绍 DOTweenPath二、操作说明1、Scene View Commands2、INfo3、Tween Options4、Path Tween Options5、Path Editor Options:轨迹编辑参数,就不介绍了6、ResetPath:重置轨迹7、Events:8、WayPoin…

什么是众创空间?他有什么特点?

众创空间,是一种为大众创新创业提供专业化服务的创业服务平台,是顺应网络时代创新创业特点和需求,通过市场化机制、专业化服务和资本化途径构建的低成本、便利化、全要素、开放式的新型创业服务平台的统称。众创空间包括创客空间、联合办公空…

KCTF2023_签到题 1

题目环境: 提示说只有管理员权限才可以访问 考虑到伪造Client-Ip准备工作: 所需工具:Kali、burp suite、火狐浏览器 抓包-伪造Client-Ip-放包 得到flag:flag{tdQvKTtPj7v1lbhkDPesHb}

redis的搭建及应用(三)-Redis主从配置

Redis主从配置 为提升Redis的高可用性,需要搭建多个Redis集群以保证高可用性。常见搭建方式有:主从,哨兵集群等,本节我们搭建一主二从的多Redis架构。 redis主从安装1主2从的方式配置,以端口号为redis的主从文件夹。 主…

python作业题百度网盘,python作业答案怎么查

大家好,小编来为大家解答以下问题,python作业题百度网盘,python作业答案怎么查,今天让我们一起来看看吧! 1 以下代码的输出结果为: alist [1, 2, 3, 4] print(alist.reverse()) print(alist) A.[4, 3, 2, …

从 Google Gemini 到 OpenAI Q*(Q-Star):调研重塑生成人工智能(AI)的研究

文章目录 一、前言二、主要内容三、总结 🍉 CSDN 叶庭云:https://yetingyun.blog.csdn.net/ 一、前言 这篇综述探讨了生成式人工智能不断发展的前景,重点关注混合专家(MoE)、多模态学习的变革性影响,以及对…

解决xcode15下载模拟器慢以及没有断点续传

问题描述:Xcode15 为了最小化安装包大小,iOS17模拟器需要单独安装。然而下载模拟器的时候,经常出现Could not download iOS... 的下载失败提示。 以下为解决方案: 一、直接下载IOS17模拟器的包 以下两种方式都可以 方法一&…

学习笔记:数据挖掘与机器学习

文章目录 一、数据挖掘、机器学习、深度学习的区别(一)数据挖掘(二)机器学习(三)深度学习(四)总结 二、数据挖掘体系三、数据挖掘的流程四、典型的数据挖掘系统 一、数据挖掘、机器学…

2023:代码岁月如歌,技术之路踏实前行

前言 转眼之间,2023年即将谢幕,这一年对于我而言充满了挑战、收获与成长。在这篇博客中,我将分享我在技术领域的一些心得体会,以及在项目和职场中的所思所感。愿这些文字能够为你带来启发,同时让我能够在反思中更进一…

Vuex状态管理(报警信息数量跟随变化)

需求:侧边栏显示报警信息数量 在store/project.js文件中定义相关状态 // 存储项目信息 const projectInfo JSON.parse(sessionStorage.getItem(projectInfo)) ? JSON.parse(sessionStorage.getItem(projectInfo)) : ; import { getUntreatedProjectAlarm } from …

Qt Creator可视化交互界面exe快速入门4

上一期介绍了信号与槽,本期介绍加法计算器 我们来新建一个项目 然后拖动设置按钮 还需要个输出框 这里拖动Line Edit 我这里只是简单演示一下,做个低配版计算器,再加个加号和一个等于号就结束了。 然后回到代码编辑部分,我们需要…

VGG网络分析与demo实例

参考自 up主的b站链接:霹雳吧啦Wz的个人空间-霹雳吧啦Wz个人主页-哔哩哔哩视频这位大佬的博客 Fun_机器学习,pytorch图像分类,工具箱-CSDN博客 VGG 在2014年由牛津大学著名研究组 VGG(Visual Geometry Group)提出,斩获该年 Imag…

Java 新手常踩得坑,清个缓存就解决了?

【IDEA教程】IDEA 如何清除缓存? 大家好,我是 JavaPub。 最近遇到群里小伙伴遇到一个很大的难题,相信这个问题很多人在初入行时都遇到过。 事情是这样,一个小伙伴刚入职一家公司,公司给了他一个任务,虽然…

公司使用了加密软件,文件无法复制

在当今数字化时代,企业面临着越来越多的数据泄露和信息安全威胁。为了保护公司的敏感信息和知识产权,许多企业选择使用加密软件来加强数据的安全性。其中一项重要的功能是防止未经授权的文件复制。本文将探讨公司使用加密软件后,为何文件无法…

枚举算法:解决问题的穷举之道(二)

💗💗💗欢迎来到我的博客,你将找到有关如何使用技术解决问题的文章,也会找到某个技术的学习路线。无论你是何种职业,我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章,也欢…

macOS系统下载安装PyCharm社区版本的流程(详细)

第一步 进入PyCharm官网,链接:Get Your Educational Tool - JetBrains 第二步 选择下拉框,根据自己的电脑芯片选择下载版本(芯片查看位置:设置-通用-关于本机)然后点击Download按钮 ​​​​​​​ -- 第…

科研学习|论文解读——融合类目偏好和数据场聚类的协同过滤推荐算法研究

论文链接(中国知网): 融合类目偏好和数据场聚类的协同过滤推荐算法研究 - 中国知网 (cnki.net) 摘要:[目的/意义]基于近邻用户的协同过滤推荐作为推荐系统应用最广泛的算法之一,受数据稀疏和计算可扩展问题影响&#x…

005.HCIA 传输层

传输层定义了主机应用程序之间端到端的连通性。传输层中最为常见的两个协议分别是传输控制协议TCP (Transmission Control Protocol)和用户数据包协议UDP (User Datagram Protocol)。 1、相关概念 a. 传输层的端口 端口范围:0-65535 知名端口:0-1023&…

图灵日记之java奇妙历险记--类和对象

目录 类的定义和使用类的定义格式 类的实例化类和对象的说明 this引用this引用的特性 对象的构造及初始化就地初始化构造方法 封装包导入包中的类自定义包 static成员static修饰成员变量static修饰成员方法 代码块代码块概念及分类构造代码块静态代码块 匿名对象 类的定义和使用…

运维工程师的出路到底在哪里

运维工程师的出路到底在哪里? 你是不是也常常听到身边的运维人员抱怨,他们的出路到底在哪里呢?别着急,让我告诉你,运维人员就像是IT界的“万金油”,他们像“修理工”一样维修服务器,像“消防员…