ZGC简介

本次调研目标选取的是jdk11(long-term support)下首次亮相的zgc。

zgc介绍简单翻译了zgc main page:ZGC简介

另外参考hotspot garbage collector team介绍zgc用的ppt:https://archive.fosdem.org/2018/schedule/event/zgc/attachments/slides/2211/export/events/attachments/zgc/slides/2211/ZGC_FOSDEM_2018.pdf

ZGC关键字

  • region base:区别于G1,zgc支持动态决定region大小,region size schema:small(2m)、medium(32m)、large(2*n m)
  • load barrier and color pointer:是zgc在回收的大部分步骤都能并发的原因 (跟其他垃圾回收器的store barrier有点区别,待深入)
  • 10ms:STW只遍历GC root,因此不会随着heap变大而变慢,这也是为什么STW能维持在10ms以内的原因
  • 64位指针:使用64位指针未使用的bit位来记录元数据,因此不支持指针压缩,不支持32位平台。目前,42位用于存储对象地址,4位存gc过程元数据,18位未开发

ZGC gc策略及回收过程相关参数(详细见:ZGC gc策略及回收过程-源码分析):

-XX:ZCollectionInterval

固定时间间隔进行gc,默认值为0。

-XX:ZAllocationSpikeTolerance

内存分配速率预估的一个修正因子,默认值为2。一般不需要更改

-XX:ZProactive

是否启用主动回收策略,默认值为true。一般建议开启

其他参数分析

本文仅对ZGC相关的参数进行分析,jdk相关参数不在本次研究范围

1、激活ZGC: -XX:UseZGC

2、配置并发线程数:-XX:ConcGCThreads=<number>

并发线程数,并发线程数太多会导致占用太多cpu时间分片,太少会导致回收速度跟不上垃圾生产速度。如果系统追求的是低时延,尽量不要让系统超负荷工作,cpu使用率尽量控制在70%以下

3、返还未使用的内存给OS:-XX:ZUncommit

这里指的是设置了xms和xmx且xmx>xms的情况,zgc默认会返回未使用的内存给操作系统,对于内存水位是重要指标的系统,返回未使用内存可以更好的观察内存使用情况。但如果要禁用这个功能,可以使用:-XX:-ZUncommit  。但无论使用哪种策略,jvm不会uncommit unsed memery导致堆大小小于xms。这也意味着如果配置xms=xmx,该特性会被隐式禁用

4、启用Large Pages:-XX:+UseLargePages -XX:ZPath

Large Pages在Linux称为Huge Pages,配置zgc使用Huge Pages可以获得更好的性能(吞吐量、延迟、启动时间),并且基本没有缺点,除了配置稍微复杂一点。配置Huge Pages大小,需要注意JVM除了堆以外其他需要使用到的内存也得算进去,一般配合ZPath使用。配置方法可以见:ZGC简介里的Enbling Large Page

5、启用NUMA Support:-XX:UseNUMA

zgc默认开启NUMA支持,意味着在分配堆内存时,会尽量使用NUMA-local的内存(比跨die访问快3倍)。但当jvm发现程序使用的只是cpu的一个子集(限定使用),则会自动禁用该特性。一般不需要关注这个特性

6、启用Transparent Huge Page(THP)

一般不建议在对延时敏感的系统下使用,THP一个使管理Huge Pages自动化的抽象层。

7、Relocate时,会根据当前region是否碎片化已大于ZFragmentationLimit,是则回收region,relocate至current candidate relocation set。

-XX:ZFragmentationLimit,默认值25

8、设置打印ZStat统计数据(cpu、内存等log)的间隔  -XX:ZStatisticsInterval

ZGC的不足

目前zgc还是被标记为实验性质的,说明还不够成熟,vm参数范围不断在调整。实验性质就是说ZGC在一些大内存的场景中表现了良好的性能,同时也说明ZGC还有一些不足,主要有:

  • ZGC仅实现了单代内存管理,也就是说没有考虑热点数据与冷数据,这个在商业的C4已经支持。据说Auzl实现的分代内存管理器比没有分代的内存管理器效率高10倍(并没有找到相关的资料文献),也就是说ZGC还有巨大的进步空间;
  • C2的支持还不够完善;
  • 不支持Graal, HDSB等功能。

Deprecated

1.Deprecated in jdk12

-XX:ZConcurrentStringTable

-XX:ZConcurrentVMWeakHandles

-XX:ZMarkStacksMax

-XX:ZWeakRoots

-XX:ZOptimizeLoadBarriers

-XX:ZStallOnOutOfMemory

-XX:ZSymbolTableUnloading

2.Deprecated in jdk13

-XX:ZUnmapBadViews

其他

-XX:ZMarkStackSpaceLimit(jdk12才有的参数):Maximum number of bytes allocated for mark stacks

-XX:ZUncommit(jdk13才有的参数):Uncommit unused memory

-XX:ZUncommitDelay (jdk13才有的参数):Uncommit memory if it has been unused for the specified amount of time (in seconds)

资料与工具

jdk jvm参数查询工具:https://chriswhocodes.com

jdk11 源码:https://download.java.net/openjdk/jdk11/ri/openjdk-11+28_src.zip

ZGC与G1一样都是region-base的垃圾回收器,G1 Paper: https://www.researchgate.net/publication/221032945_Garbage-First_garbage_collection

ZGC的实现参考了C4算法,Azul C4 Paper:https://www.azul.com/files/c4_paper_acm1.pdf

ZGC其他相关资料:https://archive.fosdem.org/2018/schedule/event/zgc/attachments/slides/2211/export/events/attachments/zgc/slides/2211/ZGC_FOSDEM_2018.pdf

ZGC相关的书:《ZGC的设计与实现》

ZGC简介:https://wiki.openjdk.java.net/display/zgc/Main

R大博客:https://www.iteye.com/blog/rednaxelafx-362738

jvm调优参考了江南白衣的博客:http://calvin1978.blogcn.com/articles/jvmoption-7.html

其他参考资料:

什么是NUMA架构:http://cenalulu.github.io/linux/numa/

huge pages:https://www.kernel.org/doc/html/latest/admin-guide/mm/hugetlbpage.html

linux memery commit: http://linuxperf.com/?p=102

Memery Barrier:https://mechanical-sympathy.blogspot.com/2011/07/memory-barriersfences.html

什么是JEP、JSR、JLS:https://stackoverflow.com/questions/51282326/what-is-the-difference-or-relation-between-jls-jsr-and-jep

ZGC深入学习的更多相关文章

  1. Caffe学习系列(16):caffemodel可视化

    通过前面的学习,我们已经能够正常训练各种数据了.设置好solver.prototxt后,我们可以把训练好的模型保存起来,如lenet_iter_10000.caffemodel. 训练多少次就自动保存 ...

  2. Git学习笔记-完全版

    注意本文参考廖雪博客: http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 一:Git ...

  3. JDK15正式发布,划时代的ZGC同时宣布转正

    你发任你发,我用Java8.本文已被 https://www.yourbatman.cn 收录,里面一并有Spring技术栈.MyBatis.JVM.中间件等小而美的专栏供以免费学习.关注公众号[BA ...

  4. JVM学习笔记(一):JVM初探

    1 来源 来源:<Java虚拟机 JVM故障诊断与性能优化>--葛一鸣 章节:第一章 本文是第一章的一些笔记整理. 2 Java里程碑 2.1 Java起源 1990年Sun公司决定开发一 ...

  5. JVM学习笔记-第三章-垃圾收集器与内存分配策略

    JVM学习笔记-第三章-垃圾收集器与内存分配策略 tips:对于3.4之前的章节可见博客:https://blog.csdn.net/sanhewuyang/article/details/95380 ...

  6. 从直播编程到直播教育:LiveEdu.tv开启多元化的在线学习直播时代

    2015年9月,一个叫Livecoding.tv的网站在互联网上引起了编程界的注意.缘于Pingwest品玩的一位编辑在上网时无意中发现了这个网站,并写了一篇文章<一个比直播睡觉更奇怪的网站:直 ...

  7. Angular2学习笔记(1)

    Angular2学习笔记(1) 1. 写在前面 之前基于Electron写过一个Markdown编辑器.就其功能而言,主要功能已经实现,一些小的不影响使用的功能由于时间关系还没有完成:但就代码而言,之 ...

  8. ABP入门系列(1)——学习Abp框架之实操演练

    作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...

  9. 消息队列——RabbitMQ学习笔记

    消息队列--RabbitMQ学习笔记 1. 写在前面 昨天简单学习了一个消息队列项目--RabbitMQ,今天趁热打铁,将学到的东西记录下来. 学习的资料主要是官网给出的6个基本的消息发送/接收模型, ...

随机推荐

  1. 008 Python基本语法元素小结

    目录 一.概要 二.保留字 三.温度转换 一.概要 缩进.注释.命名.变量.保留字 数据类型.字符串. 整数.浮点数.列表 赋值语句.分支语句.函数 input().print().eval(). p ...

  2. java字符串加密解密

    java字符串加密解密 字符串加密解密的方式很多,每一种加密有着相对的解密方法.下面要说的是java中模拟php的pack和unpack的字符串加密解密方法. java模拟php中pack: /** ...

  3. linux中启动Zookeeper

    1.先把zookeeper的安装包解压在/usr/local,如下: 2.进入zookeeper目录,创建一个data目录 3.进入同级conf目录下,里面有zoo_sample.cfg,修改该文件名 ...

  4. [币严区块链]数字货币交易所之比特币(BTC)钱包对接 | 自建节点JSON-RPC访问

    BTC钱包对接流程 一.   部署BTC钱包节点 二.   分析BTC钱包的API 三.   通过JSON-RPC访问BTC钱包API 四.   部署测试 一.部署钱包节点 交易平台对接BTC之前,要 ...

  5. 选择正确的 Fragment#commitXXX() 函数

    转自: http://www.tuicool.com/articles/q6R7nii 最新版本(v24.0.0)的 Support v4 库中的 FragmentTransaction 添加了 co ...

  6. Mars视频笔记——Animation

    Animations的使用(1) 什么是Animations 提供了一系列的动画效果,可以应用在绝大多数控件中 Animations的分类 1 Tweened Animations 渐变动画 提供了旋 ...

  7. 上海地铁游移动APP需求分析

    人们在现实的生活中会遇到各种各样的问题,有不同的需求,我们需要加以解决,开发一个软件是一个很好的方法去解决这些需求和问题.那么,作为一个软件团队如何才能准确而全面地找到这些需求呢?主要有一下几个步骤. ...

  8. CTC安装及其错误解决办法:binding.cpp:92:49: error: cannot convert ‘THCudaTensor*’ to ‘const THFloatTensor*’ for argument ‘1’ to ‘int64_t THFloatTensor_size(const THFloatTensor*, int)’

    CTC安装: 1. 在终端执行命令:git clone https://github.com/SeanNaren/warp-c) (效果如下图,大家不用管我前面括号的内容,那是我打开的虚拟环境) 2. ...

  9. UVM——寄存器模型相关的一些函数

    0. 引言 在UVM支持的寄存器操作中,有get.update.mirror.write等等一些方法,在这里整理一下他们的用法. 寄存器模型中的寄存器值应该与DUT保持同步,但是由于DUT的值是实时更 ...

  10. 连接电脑时,无法启用USB调试

    原因: 手机悬浮球 解决方案: 取消悬浮球,停止一切悬浮应用 (下面的废话可以不听) 预置条件: 手机已经打开开发者模式 开启USB调试模式 电脑能检测到手机 故事背景: 经常用手机连接电脑进行adb ...