ZGC垃圾收集器

一、ZGC概要

1.1 ZGC研究资料

这块要详细拿出来说一下。

  1. ZGC官网介绍:wiki.openjdk.java.net/display/zgc…
  2. ZGC文档(pdf,讲解详细):cr.openjdk.java.net/~pliden/sli…

这两篇文章,详细介绍了ZGC。第二个是pdf文档,可以下载下来详细看。

1.2 ZGC支持的平台

这个可以在官方文档(wiki.openjdk.java.net/display/zgc…)上看到,目前jdk11目前只支持linux。

JDK11只支持Linux64位,到jdk4开始支持windows和macOS。

1.3 ZGC的目标

我们来看看ZGC都有哪些目标,目标也就是ZGC存在的意义。

  1. 支持更大的堆内存空间。多大算是更大呢?以前都是GB级别的,现在到TB级别。在jdk11版本最大可以支持到4T的内存。(这里不是硬盘是4T,是内存,重点强调,内存。)未来一二十年的场景都涵盖到了。

  2. 支持更短的GC停顿时间,目标是10ms以内:这个更短的GC停顿时间是STW的时间。这一点就更厉害了,支持的内存打了,但是STW停顿时间却短了。

  3. 为未来的 GC 功能奠定基础. 奠定了未来垃圾收集器的一个基石。如果未来还要再升级GC,那么就会以ZGC底层算法为标准进行研究。之前我们垃圾收集都是以CMS为基石,比如G1就是在CMS的基础上发展而来的。ZGC也是在CMS的基础上发展。

  4. 吞吐量降低不超过15%:STW的时间控制的越短,那么吞吐量就会越低。这里ZGC的目标是,控制吞吐量降低不超过15%。

    通常我们GC的时间是1000ms,但是为了降低GC收集时STW的时间,我们控制STW的时间为10ms以内,产生的后果可能是GC整体时间边长了。原来是1000ms,现在变成了1150ms。这样吞吐量就降低了。

1.4 ZGC启动的命令

  1. 启动ZGC并打印日志:-XX:+UseZGC -Xmx -Xlog:gc
  2. 启动ZGC并打印详细日志:-XX:+UseZGC -Xmx -Xlog:gc

1.5 ZGC的特点:

ZGC不分代了。

我们以前分代的原因是什么?因为大部分对象都有朝生夕死的特点。所以朝生夕死的对象可能就要求尽快被清理掉。如果不分代了,结果就是,可能更频繁的触发gc,因为里面有很多朝生夕死的对象。然后每次gc,都会遍历所有的对象

ZGC为什么部分带了呢?因为分代实现起来比较麻烦,作者就先实现了一个比较简单可用的单代版本,后续优化可能会分代。

二、ZGC的内存模型

http://www.360doc.com/content/21/1104/07/46403850_1002672849.shtml
http://www.360doc.com/content/21/1107/21/46403850_1003191175.shtml
http://www.360doc.com/content/21/1107/21/46403850_1003190908.shtml
https://gitee.com/numerical-control-system
https://www.thinksaas.cn/user/space/50002/
https://zhuanlan.zhihu.com/p/430534517
https://zhuanlan.zhihu.com/p/430536898
https://zhuanlan.zhihu.com/p/430537972


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值