滴滴三面:ZGC垃圾收集器了解吗?

文章内容收录到个人网站,方便阅读hardyfish.top/

ZGC ,全称为Z Garbage Collector,是Java 11开始引入的一种低延迟、高吞吐的垃圾收集器,特点是:

  • 停顿极短 :停顿时间通常在10ms以下 ,甚至达到亚毫秒级别。
  • 并发设计:几乎所有GC操作(标记、清理、压缩)都能与应用程序并发进行,大幅减少了应用暂停时间。
  • 支持超大堆内存:最高支持TB级别的堆内存,尤其适合内存较大的应用场景。

ZGC 核心特点:

  • Region-based 内存布局

    • 将堆分割成动态大小的Region,以便实现精细的内存管理。
    • Region大小从几MB到数百MB不等,便于高效回收。
  • 并发标记、转移和重定位

    • GC线程和应用线程几乎完全并行,应用无需等待GC动作完成。
    • 大量的GC任务都发生在后台线程中。
  • 着色指针技术(Colored Pointers)

    • 指针上存储了额外信息(元数据),有效地跟踪对象状态,避免了长时间的停顿。
  • NUMA架构友好

    • 在多核多CPU服务器上有更高的性能表现。

ZGC适用场景:

  • 延迟敏感的服务:

    • 如实时交易系统、高频交易、游戏服务器、电商实时推荐系统等。
  • 大堆内存应用

    • 适合堆大小从数十GB到数TB的大型Java应用。
  • 需要实现低暂停高吞吐的业务:

    • 如实时流处理、大数据分析实时服务。

如何开启ZGC?

在启动Java应用时,通过以下参数启用ZGC:

ruby 复制代码
-XX:+UseZGC

设置初始和最大堆:

diff 复制代码
-Xms10G -Xmx10G

示例:

ruby 复制代码
java -XX:+UseZGC -Xms10G -Xmx10G -jar your-app.jar

与其他GC比较:

GC类型 停顿时间 吞吐量 并发能力 堆大小建议
ZGC (GZero) 极短(亚毫秒~毫秒级) 极强 数GB到数TB
G1GC 短(10~200ms级) 较高 较强 数GB到数百GB
CMS 短(百毫秒级) 一般 中等 数GB到几十GB

总结:

ZGC(GZero)是一款面向超低延迟场景的高性能垃圾收集器,适合追求极低延迟和稳定性能的现代化Java服务,尤其在大堆内存场景中表现突出。

相关推荐
聪明的笨猪猪40 分钟前
Java “并发容器框架(Fork/Join)”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
绿油果4 小时前
Javaweb(BeanUtils)
java·web
拧之5 小时前
✅XXL-JOB的基本使用
java
老朋友此林6 小时前
MongoDB GEO 项目场景 ms-scope 实战
java·数据库·spring boot·mongodb
追逐时光者7 小时前
一个基于 ASP.NET Core 的开源、模块化、多租户应用框架和内容管理系统
后端·.net
豆沙沙包?7 小时前
2025年--Lc165--H637.二叉树的层平均值(二叉树的层序遍历)--Java版
java·开发语言
迎風吹頭髮8 小时前
UNIX下C语言编程与实践40-UNIX 全局跳转:setjmp 与 longjmp 函数的使用与注意事项
java·c语言·unix
春风霓裳8 小时前
maven-setting配置
java·maven
小蒜学长8 小时前
springboot二手儿童绘本交易系统设计与实现(代码+数据库+LW)
java·开发语言·spring boot·后端
xqlily8 小时前
Go语言:高效简洁的现代编程语言
开发语言·后端·golang