(四)G1 garbage collector
g1专为大内存,多内核机型设计。可以兼顾高吞吐量和低暂停时间。
g1将堆分为多个相同大小内存块,并发的标记线程,使得g1掌握了各个内存块的活对象数量,
内存回收阶段,g1根据用户指定的暂停时间,选择部分内存块进行回收。选择死对象占比高的
内存块可以使得暂停时间最短。
g1采用标记复制算法,在内存回收时解决了不连续的问题。这是cms不具备的
g1可以保证应用在使用内存较大的堆时,有较短的延迟。6G堆可以低于0.5s gc延迟。
g1在逻辑上也分为新生代和老年代。同时为大对象分配了专门区域。
g1在标记复制过程中,如果发现无内存可用,会引发分配失败,从而出发 full gc(stop the world)
g1在复制对象时也会有暂停,young gc和mixed gc都会有
-XX:InitiatingHeapOccupancyPercent=<NN> 指定了开始标记周期的条件,当堆的占用比例达到NN时,开始标记周期,为mixed gc做准备。
-XX:GCPauseIntervalMillis=<NN> 可以指定最短多长可以进行一次gc
g1内存模型中的内存块的大小根据堆大小的不同而不同,内存块总的数量不会超过2048个
young gc时,g1调整新生代的大小从而达到暂停时间的目标
mixed gc时,为了达成目标,g1调整每次回收老年代的内存块数量,每个区域中活对象的占比和堆内存的浪费比例。
g1使用多个独立的记忆表来存储,各个区域的对象对应的引用。多个独立的记忆表使得各个回收线程独立工作在不同区域。
新生代的垃圾回收:
将存活对象在eden,一个sur复制到另一个sur中。存活了指定代的对象,转移到老年代。
—XX:MaxTenuringThreshold=指定存活多少代然后转移。
g1在标记循环完成前进行young gc ,完成后进行mixed gc。
标记周期的各个阶段:
初始化标记:标记root,这个阶段在young gc(stop the world)中完成
根区域扫描:
并发标记:
重新标记:
清理:
g1是自适应的垃圾回收器,可以在默认情况下自我调整,从而高效工作。
默认参数:
|
|
使用g1的建议:
1.不要设置新生代的大小,因为这样会覆盖掉暂停时间目标的设定,也就是说,只要设置暂停时间目标就好。
2.g1:应用时间:gc时间=90:10,对于parallel,应用时间:gc时间=99:1,追求短的暂停时间,必然会造成吞吐量的下降。
3.对以下参数进行试验,调整。
-XX:InitiatingHeapOccupancyPercent: Use to change the marking threshold.-XX:G1MixedGCLiveThresholdPercentand-XX:G1HeapWastePercent: Use to change the mixed garbage collection decisions.-XX:G1MixedGCCountTargetand-XX:G1OldCSetRegionThresholdPercent: Use to adjust the CSet for old regions.
g1基于标记复制算法,to space不足会报错:
解决办法:
-XX:G1ReservePercent 增加to space大小
-XX:InitiatingHeapOccupancyPercent 减小开始标记的阈值
-XX:ConcGCThreads 增加回收线程
大于g1 region一半的对象会被分配到大对象区域,每个大对象分配在一个region中,大量略微大于region一半的对象,会造成内存不连续,浪费了内存。
此时应该提高region大小,—XX:G1HeapRegionSize这些对象就不会被分配到大对象区域了。
(四)G1 garbage collector的更多相关文章
- Getting Started with the G1 Garbage Collector(译)
原文链接:Getting Started with the G1 Garbage Collector 概述 目的 这篇教程包含了G1垃圾收集器使用和它如何与HotSpot JVM配合使用的基本知识.你 ...
- G1 Garbage Collector and Shenandoah
http://www.diva-portal.se/smash/get/diva2:754515/FULLTEXT01.pdf https://is.muni.cz/th/ifz8g/GarbageC ...
- JVM(四) G1 收集器工作原理介绍
此篇文章半原创是对参考资料中的知识点进行总结,欢迎评论指点,谢谢! 部分知识点总结来自R大的帖子,下文有参考资料的链接 概述 G1 收集是相比于其他收集器(可见 上一篇文章),可以独立运 ...
- 提交并发量的方法:Java GC tuning :Garbage collector
三色算法,高效率垃圾回收,jvm调优 Garbage collector:垃圾回收器 What garbage? 没有任何引用指向它的对象 JVM GC回收算法: 引用计数法(ReferenceCou ...
- [GC]一个简单的Garbage Collector的实现
前言: 最近看了google的工程师写的一个非常简单的垃圾收集器,大概200多行C代码,感叹大牛总能够把复杂的东西通过很简单的语言和代码表达出来.为了增加自己的理解,决定把大牛的想法和代码分析一遍,与 ...
- 一个简单的Garbage Collector的实现
一个简单的Garbage Collector的实现 前言: 最近看了google的工程师写的一个非常简单的垃圾收集器,大概200多行C代码,感叹大牛总能够把复杂的东西通过很简单的语言和代码表达出来.为 ...
- AGC027 B - Garbage Collector 枚举/贪心
目录 题目链接 题解 代码 题目链接 AGC027 B - Garbage Collector 题解 对于一组选取组的最优方案为,走到一点,然后顺着路径往回取点 设选取点坐标升序为{a,b,c,d} ...
- New Garbage Collector http://wiki.luajit.org/New-Garbage-Collector
New Garbage Collector http://wiki.luajit.org/New-Garbage-Collector GC Algorithms This is a short ove ...
- agc 027 B - Garbage Collector
B - Garbage Collector https://agc027.contest.atcoder.jp/tasks/agc027_b 题意: x坐标轴上n个垃圾,有一个机器人在从原点,要清扫垃 ...
随机推荐
- HTML文档、javascript脚本的加载与解析
1.onload事件 1.1 onload事件分类 a.文档加载完成事件(包括脚本.图片等资源都加载完),绑定方法:<body onload="doSomething()"& ...
- HDU 4859 海岸线(最大流最小割)
难得的中文题,就不翻译了. 输入第一行为T,表示有T组测试数据.每组数据以两个整数N和M开始,表示地图的规模.接下来的N行,每一行包含一个长度为M的字符串,表示地图,‘.’表示陆地,’E’表示浅海域, ...
- 开源项目在真机调试(Coding iOS 客户端为例)
一.前言 iOS 13学习系列:如何在github下载开源项目到本地(Coding iOS 客户端为例)已经把 Coding iOS 客户端源码下载到本地. 但项目进行真机调试遇到很多问题. 二.问题 ...
- 关于kali2.0rolling中metasploit升级后无法启动问题的解决总结
最近在学习metasploit的使用,文中提到可以使用msfupdate命令来对metasploit的payload.exploit等进行升级,我就试了一下,没想到升级过程并不麻烦,但升级后却出现了无 ...
- HTML5 声明兼容IE的写法(转载)
HTML5 声明兼容IE的写法(转载) 1 2 3 4 5 6 7 8 9 10 <!DOCTYPE html> <!--[if IE]> <meta http-eq ...
- 各种浏览器的Hack写法(chrome firefox ie等)
Hack是针对不同的浏览器去写不同的CSS样式,从而让各浏览器能达到一致的渲染效果,那么针对不同的浏览器写不同的CSS CODE的过程,就叫CSS HACK,同时也叫写CSS Hack. 然后将Hac ...
- 常见开发需求之angular上拉加载更多
需求 移动端使用angular实现上拉加载更多的条目,这个需求比较常见,网上的插件改动起来比较麻烦,不如自己写一个最适合,以前有同事写了一个,奈何bug太多,后来改分页了,我们产品说什么都让做,没 ...
- MVC 教程汇总
http://www.cnblogs.com/powertoolsteam/archive/2015/08/13/4667892.html
- Shell 编程基础之 && 与 ||
一.引言 Shell 在执行某个命令的时候,会返回一个返回值,该返回值保存在 shell 变量 $? 中.当 $? == 0 时,表示执行成功:当 $? == 1 时,表示执行失败.有时候,下一条命令 ...
- [转] 传统 Ajax 已死,Fetch 永生
原谅我做一次标题党,Ajax 不会死,传统 Ajax 指的是 XMLHttpRequest(XHR),未来现在已被 Fetch 替代. 最近把阿里一个千万级 PV 的数据产品全部由 jQuery 的 ...