data:image/s3,"s3://crabby-images/9e146/9e14631309a982ebc823a050da71c64da289d888" alt=""
data:image/s3,"s3://crabby-images/5c07f/5c07fc229ba94dbe79e8e0dd9a19b90df35d6c3b" alt="image-20200218205007371"
举例分析CMS垃圾收集器执行过程
-verbose:gc
//会输出详细的垃圾回收的日志
-Xms20M
//堆容量的初始大小
-Xmx20M
//堆容量的最大大小 -- 两个值一般设置为一样的,这样不会出现抖动的现象。
-Xmn10M
//新生代的大小是10M
-XX:+PrintGCDetails
//打印出垃圾回收详细的信息
-XX:SurvivorRatio=8
//eden和 survivor的比例为8:1的比例。
-XX:UseConcMarkSweepGC
//指定老年代的收集器
/**
*/
// 执行前添加上述参数
public class MyTest5 {
public static void main(String[] args) {
int size = 1024 * 1024; // 1M 的容量
byte[] myAlloc1 = new byte[4 * size];
sout("111111");
byte[] myAlloc2 = new byte[4 * size];
sout("222222");
byte[] myAlloc3 = new byte[4 * size];
sout("3333333");
byte[] myAlloc4 = new byte[2 * size]; // 这个地方设置成4的话,也会报错。
sout("44444444");
}
}
》 CMS垃圾收集器 垃圾回收的7步骤。
> Task :MyTest5.main()
111111
[GC (Allocation Failure) [ParNew: 4767K->353K(9216K), 0.0023425 secs] 4767K->4451K(19456K), 0.0023675 secs] [Times: user=0.03 sys=0.00, real=0.00 secs]
222222
[GC (Allocation Failure) [ParNew: 4607K->437K(9216K), 0.0027693 secs] 8705K->8633K(19456K), 0.0028041 secs] [Times: user=0.03 sys=0.01, real=0.00 secs]
[GC (CMS Initial Mark) // 第一步
[1 CMS-initial-mark: 8196K'已使用空间大小'(10240K'老年代总的空间大小')] 12729K(19456K'堆的总空间'), 0.0004582 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]
[CMS-concurrent-mark-start] // 第二部
3333333
[CMS-concurrent-mark: 0.000/0.000 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]
[CMS-concurrent-preclean-start] // 第三部
[CMS-concurrent-preclean: 0.000/0.000 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]
[CMS-concurrent-abortable-preclean-start] // 第四部
[CMS-concurrent-abortable-preclean: 0.000/0.000 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]
[GC (CMS Final Remark) // 第五步
[YG occupancy: 6904 K (9216 K)][Rescan (parallel) , 0.0005171 secs][weak refs processing, 0.0000047 secs][class unloading, 0.0003175 secs][scrub symbol table, 0.0002325 secs][scrub string table, 0.0001332 secs][1 CMS-remark: 8196K(10240K)] 15100K(19456K), 0.0012469 secs] [Times: user=0.01 sys=0.00, real=0.00 secs]
[CMS-concurrent-sweep-start] //第六部
44444444
[CMS-concurrent-sweep: 0.000/0.000 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]
[CMS-concurrent-reset-start] // 第七部
[CMS-concurrent-reset: 0.000/0.000 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]
Heap
par new generation total 9216K, used 7068K [0x00000007bec00000, 0x00000007bf600000, 0x00000007bf600000)
eden space 8192K, 80% used [0x00000007bec00000, 0x00000007bf279f40, 0x00000007bf400000)
from space 1024K, 42% used [0x00000007bf400000, 0x00000007bf46d400, 0x00000007bf500000)
to space 1024K, 0% used [0x00000007bf500000, 0x00000007bf500000, 0x00000007bf600000)
concurrent mark-sweep generation total 10240K, used 8196K [0x00000007bf600000, 0x00000007c0000000, 0x00000007c0000000)
Metaspace
used 2806K, capacity 4486K, committed 4864K, reserved 1056768K
class space used 291K, capacity 386K, committed 512K, reserved 1048576K
G1(Gerbage First Collector)(目前被主流使用)
从JDK9开始,G1已经成为了默认的垃圾收集器。
物理内存中的新生代与老年代被消除。
data:image/s3,"s3://crabby-images/63815/638154db3275ae018fbeb47896063f60378553bf" alt="image-20200219070255660"
系统吞吐量几个重要参数:QPS(TPS)、并发数、响应时间
QPS(TPS):每秒钟request/事务 数量
并发数: 系统同时处理的request/事务数
响应时间: 一般取平均响应时间
data:image/s3,"s3://crabby-images/9ad3d/9ad3d70110d5700e53787365f4f42dcf3269205e" alt="image-20200219070622204"
data:image/s3,"s3://crabby-images/c477c/c477cd910f6559eebc007c43ea822dfbfd52ffbd" alt="image-20200219070858423"
G1有很好的吞吐量和响应能力。
G1收集器的设计目标
data:image/s3,"s3://crabby-images/45da1/45da1e84a4e9affcaaa42de4ba61a0ae8d8eeb80" alt="image-20200219071134726"
强调: GC停顿时间更加可控。
data:image/s3,"s3://crabby-images/6f5fe/6f5feff3c3840c3dc6e738e1746bef4ffd426cb4" alt="image-20200219071833361"
G1可以回收部分老年代,CMS要回收全部的老年代。
所以说G1在停顿时间上更可控。
data:image/s3,"s3://crabby-images/bbf00/bbf0031bf9cd4f0dc05ef9f179e674908d123f16" alt="image-20200219073631465"
哇,竟然都学过了。图中的内容也都知道,但是刚拿到这个图的时候不敢去看他。
execution engine : 执行引擎
JIT compiler :即时编译器。
internal : 内部的 native : 本地的
data:image/s3,"s3://crabby-images/8e143/8e143efce597c0ce77243b7b18c0a38b77876bdb" alt="image-20200219073905525"
G1收集器堆结构划分
data:image/s3,"s3://crabby-images/551cd/551cd70c46a38caab526a74807d2693dac2c3d17" alt="image-20200219074517106"
整个堆空间,不做块的区分。就当成是一个堆空间。每一个空间的使用情况都可能是三种情况之一。
data:image/s3,"s3://crabby-images/17c80/17c803a1afa3487fd6ecfae0ac22dc6749d09f97" alt="image-20200219074937169"
对每种分代内存的大小,可以动态变化。
data:image/s3,"s3://crabby-images/285b4/285b4139a3a4ea3282ae8492b189b8165032cb90" alt="image-20200219075542713"
G1 vs CMS
data:image/s3,"s3://crabby-images/23d7c/23d7c920e7e0816d01e6f555556ea59265589143" alt="image-20200219075821884"
这些差异,源于G1对物理模型设计的变化。
data:image/s3,"s3://crabby-images/f7a24/f7a243b5e1f45e119f0f36b47ea20039536a65a7" alt="image-20200219080026755"
G1重要概念
分区(Region)
data:image/s3,"s3://crabby-images/67df0/67df0257280ed4cf4d155edef0a57819ab5359d1" alt="image-20200219080118259"
data:image/s3,"s3://crabby-images/60899/608998af22b7a34f8f05a3d5c16f6104eeda23f3" alt="image-20200219080219989"
G1 : 垃圾优先。 即首先收集垃圾最多的分区。
data:image/s3,"s3://crabby-images/245c5/245c5e5cf42daceb571f6f5bdd851ca59d4bcbcf" alt="image-20200219080501983"
新生代满的时候,G1 对整个新生代进行回收。
data:image/s3,"s3://crabby-images/2d556/2d55615184e336ae8b3d3b05acf995d3a81363b2" alt="image-20200219080549430"
收集集合(CSet)
data:image/s3,"s3://crabby-images/2dff9/2dff9dd00d6e296329e00f49375091ffabe0c274" alt="image-20200219080612134"
CSet:一组将要被回收的空间的集合。
已记忆集合(RSet)
data:image/s3,"s3://crabby-images/63356/6335634d019c4f18bdd1a7a6fdc6ad2eab5d4552" alt="image-20200219080727462"
data:image/s3,"s3://crabby-images/7046e/7046ee1ed27f5cf28dc934545a71c37f339c8193" alt="image-20200219080856614"