G1 和 CMS

1、CMS

CMS(Concurrent Mark Sweep,并发标记清除,是为了解决早期垃圾收集器在执行垃圾回收时导致应用程序暂停时间过长的问题而设计的。

CMS的工作流程主要包括以下几个阶段:

  1. 初始标记(Initial Mark):这个阶段是Stop-The-World事件,所有应用线程暂停,垃圾收集器仅标记与根对象直接关联的对象。这个阶段很短。

  2. 并发标记(Concurrent Mark):在这个阶段,应用线程与垃圾收集线程并发执行。垃圾收集器会遍历整个堆,标记出所有存活的对象。这个过程比较耗时,但因为与用户线程并发执行,所以不会导致长时间的暂停。

  3. 重新标记(Remark):这是另一个短暂的Stop-The-World事件,用于修正并发标记期间因用户程序继续运行而可能产生的标记变动。相比初始标记,这个阶段稍长一些,因为它需要处理整个堆的信息。

  4. 并发清除(Concurrent Sweep):此阶段也是与用户线程并发执行的,垃圾收集器会清除那些被标记为死亡的对象所占用的内存空间,回收空间供后续使用。

CMS的优点在于其低延迟特性,能够在大部分垃圾回收工作与应用程序并发执行,从而减少因垃圾回收而导致的暂停时间。然而,CMS也有一些缺点,比如:

  • 对CPU资源消耗较高:由于其并发标记和清除的特性,CMS在运行时会占用较多的CPU资源。
  • 无法处理浮动垃圾(Floating Garbage):在并发标记和清除阶段,新产生的垃圾不能被这次收集处理,需要等到下一次收集。
  • 可能出现“Concurrent Mode Failure”:如果在老年代剩余空间不足以容纳新生代晋升的对象时,会导致CMS停止并发收集,转而执行完全的垃圾收集(Full GC),这会导致长时间的应用暂停。

尽管CMS在很长一段时间内被广泛使用于对延迟敏感的服务,但随着G1垃圾收集器的发展和完善,CMS在JDK 9中已被废弃,并在JDK 14中完全移除,推荐使用G1或ZGC、Shenandoah等现代垃圾收集器作为替代。

2、G1

G1垃圾收集器(Garbage First Garbage Collector)是Oracle在Java 7中引入的一种高性能垃圾收集器,旨在替代传统的CMS(Concurrent Mark-Sweep)垃圾收集器。它结合了多种垃圾收集技术,旨在提供低停顿、高吞吐量和高效的内存管理;

G1垃圾收集器的工作机制和主要算法:

分区(Region)机制

  • Region:G1将整个堆划分成多个大小相等的独立区域(Region),每个Region通常为1MB到32MB,根据堆的大小自动调整。
  • 灵活性:Region可以充当Eden区、Survivor区或老年代的一部分,这种设计使得内存管理更加灵活,有助于优化垃圾收集过程。

年轻代收集(Young GC)

  • 复制算法:新生代使用复制算法(Copying),将存活对象从Eden区和一个Survivor区复制到另一个Survivor区。这种方式可以快速整理内存,提高新生代回收的效率。

并发标记周期(Concurrent Marking Cycle)

  1. 初始标记(Initial Marking):暂停所有应用线程,标记从根对象(GC Roots)直接可达的对象。这个过程时间较短。
  2. 并发标记(Concurrent Marking):在应用线程运行时,进行可达性分析,标记所有可达的对象。这个过程中不需要暂停应用线程。
  3. 最终标记(Final Marking):稍微暂停应用线程以完成标记过程,包括处理并发标记阶段新创建的对象。
  4. 筛选回收(Selection Phase):根据之前标记收集的信息,整理并选择有足够垃圾的Region进行回收。这个过程会计算每个Region的回收收益,优先清理垃圾最多的Region。

混合收集(Mixed GC)

  • 混合GC:这是G1垃圾收集器的特性之一,结合了新生代和老年代的垃圾收集。混合收集不仅回收新生代(Eden和Survivor),同时还会选择性地回收一部分老年代的Region。
  • 标记-压缩:在混合GC步骤中,G1对老年代的回收通常使用的是标记-压缩(Mark-Compact)算法。标记阶段标记存活的对象,压缩阶段会移动对象来消除内存碎片,从而可以有连续的空间分配给新的大对象。

回收过程中的暂停时间和吞吐量

  • 暂停时间:G1垃圾收集器设计了暂停时间预测算法,可以根据用户配置的最大暂停时间(-XX:MaxGCPauseMillis)来适应性调整收集行为。
  • 吞吐量:尽量增加应用线程的运行时间,减少垃圾收集的总停顿时间。

总体流程

  1. 启动Young GC:当Eden区满时触发年轻代收集,使用复制算法将存活对象移动到Survivor区或老年代。
  2. 并发标记阶段启动:当老年代使用率超过特定阈值时,G1启动并发标记周期。
  3. 混合收集:在并发标记周期完成后,会进行多次混合收集,回收新生代和部分老年代。
  4. 完全垃圾收集(Full GC):作为最后的手段,当其他方法无法腾出足够空间时,G1会进行Full GC,这是代价最高的一种垃圾收集方式。

通过以上综合设计,G1垃圾收集器能够在大堆内存环境中有效地管理内存,降低垃圾收集停顿时间,提高应用的响应性和吞吐量。

3、是否可以理解:G1的内存管理 = CMS + 标记整理

标记-整理算法:在标记-整理算法中,存活对象会被移动以压缩和消除内存碎片,这个过程需要停止所有应用线程(“Stop-The-World”),导致较长的停顿时间。

虽然CMS可以通过引入标记-整理算法来减少碎片,但无法有效解决长时间停顿和并发处理的复杂性问题。G1通过划分Region+混合收集,使得G1能够更加灵活地选择收集哪些区域,而不是像传统的分代收集器那样对整个年轻代或老年代进行回收。

G1混合收集触发场景

  1. 周期性触发:G1有一个称为“Initiating Heap Occupancy Percent”(IHOP)的阈值,默认情况下,当整个Java堆的使用量达到这个阈值时(默认设置通常是45%到70%之间,可以通过-XX:InitiatingHeapOccupancyPercent参数调整),G1会启动一次混合收集。这意味着G1会定期检查堆的占用情况,一旦达到设定的阈值,就会触发一次收集以回收空间。

  2. 避免内存耗尽:除了基于IHOP的触发机制外,G1还会根据实际的内存分配速率和当前堆的使用情况动态调整,确保有足够的空闲空间来满足应用程序的内存需求,避免因为没有足够的空间分配对象而导致的Full GC。

  3. 目标停顿时间管理:G1在执行时会尽量维持用户设定的目标停顿时间(通过-XX:MaxGCPauseMillis参数指定)。如果系统检测到为了满足这个目标停顿时间,需要进行老年代的清理,那么也会触发混合收集,即使没有达到IHOP设定的阈值。

  4. 碎片整理需求:G1在运行过程中会持续监控堆的碎片化程度。如果发现老年代区域过于碎片化,影响了对象分配或者满足不了预设的内存分配需求,G1也可能决定进行一次混合收集来整理内存,减少碎片。

混合收集的主要目的是回收一部分老年代区域,同时保持暂停时间的可预测性,并通过这种方式平衡吞吐量与响应时间的需求。在整个过程中,G1会优先回收垃圾最多(即回收效益最高的)区域,以提高收集效率。

4、为什么选择G1

JDK 9之后,G1(Garbage First)垃圾收集器成为了默认的垃圾收集器。这一改变主要基于以下几点考虑:

  1. 适应性更强:G1是一种跨代收集器,能够自动管理整个Java堆,包括年轻代和老年代,而不仅仅是老年代(如同CMS)。

  2. 更低暂停、更高吞吐:通过并发和并行处理(充分利用多核处理器的能力),以及灵活的Region管理,减少了应用的全局停顿时间,适合对响应时间要求较高的应用。

  3. 内存管理更高效:通过标记-压缩算法和区域回收,有效地管理内存碎片,避免大对象分配困难的问题。同时引入了混合收集模式,即在年轻代收集的同时,也会并发地回收一部分老年代,这有助于减少老年代的碎片化问题。

参考:

  • https://juejin.cn/post/6844903893906751501
  • https://docs.oracle.com/javase/9/gctuning/garbage-first-garbage-collector.htm#JSGCT-GUID-ED3AB6D3-FD9B-4447-9EDF-983ED2F7A573

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【HTML入门】第四课 - 换行、分割横线和html的注释

这一小节,我们继续说HTML的入门知识,包括换行、横线分割以及注释(html的注释)。 目录 1 换行 2 分割横线 3 html注释 1 换行 html中分为块元素和行内元素。这一小节呢,先不说这些元素们,我们先说一下换…

安装Gradle

官网文档 https://gradle.org/ 腾讯下载镜像:https://mirrors.cloud.tencent.com/gradle/ 文档:https://docs.gradle.org/current/userguide/userguide.html 命令行文档:https://docs.gradle.org/current/userguide/command_line_interface.…

Python提取视频文案

Python提取视频文案 1、背景描述2、视频转音频3、音频转文字 1、背景描述 在多媒体应用中,视频是一个信息量巨大的载体。然而,有时我们需要从视频中提取语音并转换为文本,以用于文本分析和机器学习训练 其中主要涉及到两个过程:视…

String类(STL开始)

相信大家都知道STL在C中的重要性,作为其模板库中的一部分,包含了常见的数据结构和算法,是C的标准库 而我们今天要讲的String类(String底层是一个字符顺序数组的顺序表对象,可以归类为容器),其实…

MySQL安装时initializing database失败

问题页面: 解决方法: 1.勾选红框中的选项: 2.将下图红框中全部改为英文: 然后一路next就可以了。

洛谷 P3613 学习用map代替大大大数组的好题

题目链接:P3613 【深基15.例2】寄包柜 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 题目截图: 题意分析: 非常简单的存入和取出操作 唯一的 “难点” 在于 数组开不到 a[100007][100007],会暴内存 非常巧妙的引入 map 来解决…

广州银行多份招股书数据货不对板:内控风险难平,IPO曲折前行

作者|芋圆 来源|贝多财经 6月29日,广州银行第五次更新了招股说明书。 作为制造业大省的头部城商行,广州银行的发展一直备受关注。拆解可知,广州银行2023年在盈利能力、内控、资本充足性、资产质量等方面的表现,凸显了该行接下来…

Linux三剑客(grep、awk和sed)操作及与管道结合使用

1. 总览 grep、sed和awk被称为Linux三剑客,是因为它们在文本处理和数据操作方面极其强大且常用。 Linux三剑客在文件处理中的作用: grep(数据查找定位):文本搜索工具,在文件中搜索符合正则表达式的文本内容…

小阿轩yx-Haproxy搭建Web群集

小阿轩yx-Haproxy搭建Web群集 Haproxy 简介 提供高可用性 能做出标准的负载均衡 支持虚拟主机 具备健康检查能力 能用于各式各样的代理 轻量级代理环境 解决方案优势 免费 快速 可靠 特性 特别适用于那些负载特大的web站点,这些站点通常又需要会话保持或…

明明已经安装了python中的某个库,但是还是报错ModuleNotFoundError: No module named ‘sklearn‘

问题: 明明已经安装了python中的某个库,但是还是报错ModuleNotFoundError: No module named sklearn 解决方法: 卸载重新安装一下即可 pip uninstall scikit-learn pip install scikit-learn 成功解决!!&#xff…

高创新 | CEEMDAN-VMD-GRU-Attention双重分解+门控循环单元+注意力机制多元时间序列预测

目录 效果一览基本介绍模型设计程序设计参考资料 效果一览 基本介绍 高创新 | CEEMDAN-VMD-GRU-Attention双重分解门控循环单元注意力机制多元时间序列预测 本文提出一种基于CEEMDAN 的二次分解方法,通过样本熵重构CEEMDAN 分解后的序列,复杂序列通过VMD…

【Threejs进阶教程-着色器篇】1. Shader入门(ShadertoyShader和ThreejsShader入门)

ThreejsShader入门 关于本Shader教程认识ShaderShader和Threejs的关系WebGLShaderThreejsShaderShadertoyShader其他Shader 再次劝退数学不好的人从ShaderToy开始Shader的代码是强类型glsl的类型,变量,内置函数,关键字关于uv基于UV的颜色处理…

PCL 点云FPFH特征描述子

点云FPFH特征描述子 一、概述1.1 FPFH概念1.2 基本原理1.3 PFH和FPFH的区别二、代码实现三、结果示例一、概述 1.1 FPFH概念 快速点特征直方图(FPFH)描述子:计算 PFH 特征的效率其实是十分低的,这样的算法复杂度无法实现实时或接近实时的应用。因此,这篇文章将介绍 PFH 的简…

【java web 01】3小时快速学习前端知识(收藏备用)

3小时快速学习前端知识【全栈专用】 一、教程简介1.1 Java 开发为何学Web技术1.2 课程设计1.3 课前准备 二、HTML2.1 Html简介2.1.1 HTML、CSS、JS分别有什么作用2.1.2 什么是HTML2.1.3 什么是标记语言 2.2 Hello,Html2.2.1 HTML基础结构2.2.2 专业词汇2.2.3 语法细…

面试经典150题

合并两个有序数组 两个按非递减顺序排列的整数数组nums1和nums,另有两个整数m和n,分别表示nums1和nums2中的元素数组。 请合并nums2到nums1中,使合并后的数组同样按非递减顺序排列。 直接合并后排序 class Solution { public:void merge(…

解码Python字符串:‘r‘、‘b‘、‘u‘和‘f‘前缀的全面指南

📖 正文 1 字符串前加’r’ 表示原始字符串,消除转义 print(abc\nde) # abc # deprint(rabc\nde) # abc\nde在下面这个列子中,如果不在路径字符串前面加r那么,路径中的空格就会出现问题 print(rD:\01 programming\09python\py…

【ARM系列】GIC600AE功能安全

GIC600AE功能安全 1.GIC600AE主要安全机制分布图:2.Fault Management Unit1.GIC block的错误如何上报到FMU?2.汇总到FMU的错误如何上报?3.Error Record format4.Safety Mechanism GIC600AE在原GIC600版本基础上增加了FuSa功能,所增…

RIP环境下的MGRE网络

首先将LSP的IP地址进行配置 其他端口也进行同样的配置 将serial3/0/1配置25.0.0.2 24 将serial4/0/0配置35.0.0.2 24 将GE0/0/0配置45.0.0.2 24 进行第二步 R1与R5之间使用ppp的pap认证 在R5中进行配置 在aaa空间中创建账号和密码 将这个账号和密码使用在ppp协议中 然后…

zdppy+onlyoffice+vue3解决文档加载和文档强制保存时弹出警告的问题

解决过程 第一次排查 最开始排查的是官方文档说的 https://api.onlyoffice.com/editors/troubleshooting#key 解决方案。参考的是官方的 https://github.com/ONLYOFFICE/document-server-integration/releases/latest/download/Python.Example.zip 基于Django的Python代码。 …