JVM高级篇之GC

文章目录

  • 版权声明
  • 垃圾回收器的技术演进
  • Shenandoah
    • Shenandoah GC体验
    • Shenandoah GC循环过程
  • ZGC
    • ZGC简介
    • ZGC的版本更迭
    • ZGC体验&使用
    • ZGC的参数设置
    • ZGC的调优

版权声明

  • 本博客的内容基于我个人学习黑马程序员课程的学习笔记整理而成。我特此声明,所有版权属于黑马程序员或相关权利人所有。本博客的目的仅为个人学习和交流之用,并非商业用途。
  • 我在整理学习笔记的过程中尽力确保准确性,但无法保证内容的完整性和时效性。本博客的内容可能会随着时间的推移而过时或需要更新。
  • 若您是黑马程序员或相关权利人,如有任何侵犯版权的地方,请您及时联系我,我将立即予以删除或进行必要的修改。
  • 对于其他读者,请在阅读本博客内容时保持遵守相关法律法规。
  • 本博客中的部分观点和意见仅代表我个人,不代表黑马程序员的立场。

垃圾回收器的技术演进

在这里插入图片描述

  • CMS会产生内存碎片:没有整理功能,会导致最终产生需要碎片,导致内存浪费
    在这里插入图片描述
  • 解决方案:
  1. 产生FULLGC并且进行整理,此时会产生长时间STW
  2. 退化成串行回收,产生长时间的STW

  • 新一代的垃圾回收器
    在这里插入图片描述
  • 不同的垃圾回收器设计的目标是不同的。Parallel GC、G1更注重较高的吞吐量;Shenandoah、ZGC更注重较低的延迟时间

在这里插入图片描述

Shenandoah

  • Shenandoah 是由Red Hat开发的一款低延迟的垃圾收集器,Shenandoah 并发执行大部分 GC 工作,包括并发的整理,堆大小对STW的时间基本没有影响。
  • Shenandoah GC文档
    在这里插入图片描述

Shenandoah GC体验

  • 可以使用docker构建Shenandoah GC体验
# Update the image to the most recent one:
$ docker pull shipilev/openjdk
$ docker pull shipilev/openjdk:17
$ docker pull shipilev/openjdk:11# Run the latest version:
$ docker run --rm -it shipilev/openjdk java -XX:+UseShenandoahGC -Xlog:gc -version
[0.007s][info][gc] Using Shenandoah
...# Run the JDK 17 version:
$ docker run --rm -it shipilev/openjdk:17 java -XX:+UseShenandoahGC -Xlog:gc -version
[0.007s][info][gc] Using Shenandoah
...# Run the JDK 11 version:
$ docker run --rm -it shipilev/openjdk:11 java -XX:+UseShenandoahGC -Xlog:gc -version
[0.008s][info][gc] Using Shenandoah
...

Shenandoah GC循环过程

在这里插入图片描述

GC(3) Pause Init Mark 0.771ms
GC(3) Concurrent marking 76480M->77212M(102400M) 633.213ms
GC(3) Pause Final Mark 1.821ms
GC(3) Concurrent cleanup 77224M->66592M(102400M) 3.112ms
GC(3) Concurrent evacuation 66592M->75640M(102400M) 405.312ms
GC(3) Pause Init Update Refs 0.084ms
GC(3) Concurrent update references  75700M->76424M(102400M) 354.341ms
GC(3) Pause Final Update Refs 0.409ms
GC(3) Concurrent cleanup 76244M->56620M(102400M) 12.242ms
  • 这些阶段大致执行以下操作:
  1. Init Mark(初始化标记)启动并发标记。它为堆和应用程序线程准备并发标记,然后扫描根集。这是周期中的第一次暂停,最主要的时间消耗者是根集扫描。因此,其持续时间依赖于根集的大小。
  2. Concurrent Marking(并发标记)遍历堆,并追踪可达对象。这个阶段与应用程序并行运行,其持续时间取决于堆中活跃对象的数量和对象图的结构。由于应用程序在此阶段可以自由分配新数据,因此堆占用率在并发标记期间上升。
  3. Final Mark(最终标记)通过排空所有待处理的标记/更新队列并重新扫描根集来完成并发标记。它还通过确定要疏散的区域(收集集)、预先疏散一些根,并通常为下一个阶段准备运行时来初始化疏散。这部分工作可以在Concurrent Precleaning(并发预清理)阶段并发完成。这是周期中的第二次暂停,这里最主要的时间消耗者是排空队列和扫描根集。
  4. Concurrent Cleanup(并发清理)回收即时垃圾区域——即,并发标记后检测到没有活跃对象存在的区域。
  5. Concurrent Evacuation(并发疏散)将对象从收集集复制到其他区域。这是与其他OpenJDK GCs的主要区别。这个阶段再次与应用程序并行运行,因此应用程序可以自由分配。其持续时间取决于本周期选择的收集集的大小。
  6. Init Update Refs(初始化更新引用)启动更新引用阶段。它几乎不做任何事情,只确保所有GC和应用程序线程已完成疏散,然后为下一个阶段准备GC。这是第三次暂停,也是所有中最短的。
  7. Concurrent Update References(并发更新引用)遍历堆,并更新在并发疏散期间移动的对象的引用。这是与其他OpenJDK GCs的主要区别。其持续时间取决于堆中的对象数量,但不依赖于对象图的结构,因为它是线性扫描堆的。这个阶段与应用程序并行运行。
  8. Final Update Refs(最终更新引用)通过重新更新现有根集来完成更新引用阶段。它还回收收集集中的区域,因为现在堆不再有对那些(过时的)对象的引用。这是周期中的最后一次暂停,其持续时间取决于根集的大小。
    9。 Concurrent Cleanup(并发清理)回收现在没有引用的收集集区域。

ZGC

ZGC简介

  • ZGC 是一种可扩展的低延迟垃圾回收器。ZGC 在垃圾回收过程中,STW的时间不会超过一毫秒,适合需要低延迟的应用。支持几百兆到16TB 的堆大小,堆大小对STW的时间基本没有影响。
  • ZGC降低了停顿时间,能降低接口的最大耗时,提升用户体验。但吞吐量不佳,所以如果服务关注QPS(每秒的查询次数)G1是比较不错的选择。
    在这里插入图片描述

ZGC的版本更迭

在这里插入图片描述

ZGC体验&使用

  • OracleJDK和OpenJDK中都支持ZGC,阿里的DragonWell龙井JDK也支持ZGC但属于其自行对OpenJDK 11的
    ZGC进行优化的版本。

  • 【建议使用JDK17之后的版本,延迟较低同时无需手动配置并行线程数。】

  • 分代 ZGC添加如下参数启用 -XX:+UseZGC -XX:+ZGenerational

  • 非分代 ZGC通过命令行选项启用 -XX:+UseZGC

  • 使用 adoptopenjdk:17 作为基础镜像,进行体验,创建名称为Dockerfile的普通文本文件

#使用adoptopenjdk作为基础镜像,选择Java 17版本
FROM adoptopenjdk:17-jdk-hotspot#设置工作目录
WORKDIR /app#拷贝应用程序jar包到镜像中
COPY target/your-application.jar /app/your-application.jar#暴露应用程序的端口(如果需要)
EXPOSE 8080#设置启动命令,指定使用ZGC作为垃圾收集器
CMD ["java", "-XX:+UseZGC", "-jar", "your-application.jar"]
  1. 构建 Docker 镜像并运行容器, 并配置 ZGC 的 Java 应用程序
docker build -t your-image-name .
docker run -d -p 8080:8080 your-image-name

ZGC的参数设置

  • ZGC在设计上做到了自适应,根据运行情况自动调整参数,让用户手动配置的参数最少化。
    • 自动设置年轻代大小,无需设置-Xmn参数。
    • 自动晋升阈值(复制中存活多少次才搬运到老年代),无需设置-XX:TenuringThreshold
    • JDK17之后支持自动的并行线程数,无需设置-XX:ConcGCThreads
  • 需要设置的参数:
    -Xmx 值 (最大堆内存大小):ZGC最重要的一个参数,必须设置。ZGC在运行过程中会使用一部分内存用来处理垃圾回收,所以尽量保证堆中有足够的空间。设置多少值取决于对象分配的速度,根据测试情况来决定。
  • 可以设置的参数:
    -XX:SoftMaxHeapSize=值:ZGC会尽量保证堆内存小于该值,在内存靠近这个值时会尽早地进行垃圾回收,但是依然有可能会超过该值。例如,-Xmx5g -XX:SoftMaxHeapSize=4g ZGC会尽量保证堆内存小于4GB,最多不会超过5GB。

ZGC的调优

  • ZGC 中可以使用Linux的Huge Page大页技术优化性能,提升吞吐量、降低延迟。
  • 注意:安装过程需要 root 权限,所以ZGC默认没有开启此功能。

操作步骤:

  1. 计算所需页数,Linux x86架构中大页大小为 2 M B 2MB 2MB,根据所需堆内存的大小估算大页数量。比如堆空间需要 16 G 16G 16G,预留 2 G 2G 2G(JVM需要额外的一些非堆空间),那么页数就是 18 G / 2 M B = 9216 18G / 2MB = 9216 18G/2MB=9216
  2. 配置系统的大页池以具有所需的页数(需要root权限):
$ echo 9216 > /sys/kernel/mm/hugepages/hugepages-2048kB/nr_hugepages
  1. 添加参数 − X X : + U s e L a r g e P a g e s -XX:+UseLargePages XX:+UseLargePages 启动程序进行测试

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

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

相关文章

[Windows] Wireshark v3.6.1 【网络抓包工具】

Wireshark是世界上最流行的网络分析工具。 这个强大的工具可以捕捉网络中的数据,并为用户提供关于网络和上层协议的各种信息。与很多其他网络工具一样,Wireshark也使用pcap network library来进行封包捕捉。 Wireshark的优势:- 绿色版免安…

Excel 文件底部sheet 如何恢复

偶然打开一个excel文件,惊奇地发现:原来excel文件底部的若干个sheet居然全都看不到了。好神奇啊。 用其它的电脑打开同样的excel文件,发现:其实能看到的。说明这个excel文件并没有被损坏。只要将修改相关设置。就可以再次看…

h5 笔记3 多媒体素材运用

关于电影编码 我们经常用扩展名来判断文件的类型,但是对于影音文件未必适用,影音文件的文件格式(container)和编码(codec)之间并非绝对相关。决定影音文件播放的关键在于浏览器是否含有适合的影音编解码技术。 笔记来源: ©《HTML5CSS3J…

SpringFramework实战指南(八)

SpringFramework实战指南&#xff08;八&#xff09; 5.1 场景设定和问题复现5.2 解决技术代理模式 5.1 场景设定和问题复现 准备AOP项目 项目名&#xff1a;spring-aop-annotation pom.xml <dependencies><!--spring context依赖--><!--当你引入Spring Conte…

图像识别网络与训练策略——基于经典网络架构训练图像分类模型

基于经典网络架构训练图像分类模型 总体框架 数据预处理部分&#xff1a;- 数据增强&#xff1a;torchvision中transforms模块自带功能&#xff0c;比较实用 - 数据预处理&#xff1a;torchvision中transforms也帮我们实现好了&#xff0c;直接调用即可 - DataLoader模块直接…

小小算式(1 + 2) * (3 + 4)背后的大道理

目录 前缀表示法&#xff08;波兰表达式&#xff09; 中缀表达法 后缀表达法&#xff08;逆波兰表达式&#xff09; 三种表达法的相互转换 练习&#xff1a;逆波兰表达式求值 前缀表示法&#xff08;波兰表达式&#xff09; 波兰表示法&#xff08;英语&#xff1a;Polis…

【二分查找】Leetcode 寻找旋转排序数组中的最小值

题目解析 153. 寻找旋转排序数组中的最小值 我们可以发现旋转后的数组是有这样一个顺序特征&#xff1a; 1.要么是旋转长度次&#xff0c;刚好还是原来的数组 2.要么一定存在一段一段的升序区间&#xff0c;再其中一段的升序区间中就存在最小值 算法讲解 但是我们这一次使用…

代码随想录阅读笔记-二叉树【修剪二叉搜索树】

题目 给定一个二叉搜索树&#xff0c;同时给定最小边界L 和最大边界 R。通过修剪二叉搜索树&#xff0c;使得所有节点的值在[L, R]中 (R>L) 。你可能需要改变树的根节点&#xff0c;所以结果应当返回修剪好的二叉搜索树的新的根节点。 思路 相信看到这道题目大家都感觉是…

健身房如何通过软文获客?媒介盒子告诉你

如今全民健康意识上升&#xff0c;大家越来越重视运动带给人的获得感以及成就感&#xff0c;对于健身房来说&#xff0c;适当进行推广&#xff0c;不仅可以提高品牌知名度&#xff0c;还能吸引更多的潜在客户。今天媒介盒子就从专业角度和大家聊聊&#xff1a;健身房如何通过软…

分表?分库?分库分表?实践详谈 ShardingSphere-JDBC

如果有不是很了解ShardingSphere的可以先看一下这个文章&#xff1a; 《ShardingSphere JDBC?Sharding JDBC&#xff1f;》基本小白脱坑问题 阿丹&#xff1a; 在很多开发场景下面&#xff0c;很多的技术难题都是出自于&#xff0c;大数据量级或者并发的场景下面的。这里就出…

什么是 SD NAND?

什么是 CS 创世 SD NAND 呢&#xff1f;很多的朋友一直想知道这个问题。 什么是 CS 创世 SD NAND 呢&#xff1f;很多的朋友一直想知道这个问题。今天我们雷龙也精心准备了 SD NAND 的一个介绍。其实很多工程师朋友对 CS 创世 SD NAND 有很多称呼。比如&#xff1a;贴片式 T 卡…

Java多线程+分治求和,太牛了

shigen坚持更新文章的博客写手&#xff0c;擅长Java、python、vue、shell等编程语言和各种应用程序、脚本的开发。记录成长&#xff0c;分享认知&#xff0c;留住感动。 个人IP&#xff1a;shigen 最近的一个面试&#xff0c;shigen简直被吊打&#xff0c;简历上写了熟悉高并发…