理解GC日志

理解GC日志

PS : 本文乃学习整理参考而来


以下是案例输出:

33.125:[GC[DefNew:3324K->152K(3712K),0.0025925 secs] 3324K->152K(11904K),0.0031680 secs]

100.667:[Full GC[Tenured:0K->210K(10240K),0.0149142 secs] 4603K->210K(19456K),[Perm:2999K->2999K(21248K)],
0.015007 secs] [Times:user=0.01 sys=0.00,real=0.02 secs]

最前面的数字“33.125”“100.667”代表了GC发生的时间,这个数字的含义是Java虚拟启动以来经过的秒数

“[GC”“[Full GC” 代表这次垃圾收集的停顿类型,而不是用来区分新生代GC还是老年代GC的。如果有“Full”说明这次GC是发生过Stop The World
如下这段新生代收集器ParNew的日志也会出现“[Full GC”(这一般是因为出现了分配担保失败之类的问题,导致了STW)。
[Full GC 283.736:[ParNew:261599K->261599K(261952K),0.0000288 secs]]

接下来的“[DefNew”、“[Tenured”、“[Perm”表示GC发生的区域,这里显示的区域名称与使用的GC收集器是密切相关的,例如上面所使用的Serail收集器中新生代名为“Default New Generation”,所以显示的是“[DefNew”。如果是ParNew收集器,新生代名称变为“[ParNew”,意味“Parallel New Generation”。如果采用Parallel Scavenge收集器,那它配套的新生代为“PSYoungGen”

后面方括号内部的“3324K->152K(3712K)”含义是“GC前该内存区域已使用的容量->GC后该内存区域已使用的容量(该内存区域总容量)”。而在方括号之外的“3324K->152(11904K)”表示“GC前Java堆已使用容量->GC后Java堆已使用容量(Java堆总容量)”。再往后“0.0025925”表示该内存区域GC所占用的时间,单位是

有的收集器会给出更具体时间数据。如:“[Times:user=0.01 sys=0.00 ,real=0.02 secs]”这里面的user、sys、real与Linux的time命令说输出的时间含义一致,分别代表用户态消耗的CPU时间内核态消耗的CPU时间操作从开始到结束所经过的墙钟(Wall Clock Time)。


发布了41 篇原创文章 · 获赞 7 · 访问量 1万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章