美文网首页
理解GC日志

理解GC日志

作者: an_bear | 来源:发表于2018-09-02 09:38 被阅读0次

有如下一段GC日志:

1.最前面的数字0.059,0.086代表GC发生的时间,这个数字的含义是从Java虚拟机启动以来经过的秒数。

2.GC日志开头的"[GC"和"[Full GC"说明了这次垃圾收集发生的停顿类型,而不是来区分新生代GC还是老年代GC。如果有"Full",说明这次GC是发生了STW。(Allocation Failure – 引起垃圾回收的原因. 本次GC是因为年轻代中没有任何合适的区域能够存放需要分配的数据结构而触发的.)

3."[DefNew","[Tenured","[Perm",表示GC发生的区域,这里显示的区域名称与使用的GC收集器是密切相关的,例如Serial收集器中新生代名为Default New Generation,所以显示[DefNew。如果是ParNew收集器,新生代名称就会变为[ParNew,意为Parallel New Generation,如果采用Parallel Scavenge收集器,那么它配套的新生代称为PSYoungGen,老年代和永久代同理,名称也是有由收集器决定。

4.后面方括号内部的384k->64k(448k),含义是“GC前该内存区域已经使用容量->GC后该内存区域已经使用容量(该内存区域总容量)”,方括号之外的384k->266k(1048512k)表示“GC前Java堆已经使用量->GC后Java堆已经使用量(Java堆总容量)”

5.“0.0009127 secs”表示GC所占用的时间

6."[Times: user=0.00 sys=0.00, real=0.00 secs]" 分别表示用户态消耗的CPU时间,内核态消耗的CPU时间,和操作开始到结束所经历过的墙钟时间。CPU时间与墙钟时间的的区别是,墙钟时间包含各种非运算的等待耗时,如等待磁盘I/O;但当系统有多CPU或者多核的话,多线程操作会叠加这些CPU时间,所以如果看到,user或sys时间超过real时间也是完全正常的。

相关文章

  • 通过 gc.log 调优 JVM

    一、GC 日志查看 GC 日志默认是关闭的,需要查看 GC 日志首先需要开启 GC 日志。 常用 GC 日志的配置...

  • 理解GC日志

    有如下一段GC日志: 1.最前面的数字0.059,0.086代表GC发生的时间,这个数字的含义是从Java虚拟机启...

  • 理解GC日志

    每一种收集器的日志形式都是由他们自身的实现所决定,换而言之,每个收集器的日志格式都可以不一样。但虚拟机设计者为了方...

  • 理解GC日志

    阅读GC日志是处理Java虚拟机内存问题的基础技能,它只是一些人为确定的规则,没有太多技术含量。在本书的第1版中没...

  • 理解GC日志

    前言 每一种收集器的日志形式都由他们自身实现所决定的,所以会不同,但是一般大家都会维持一定的共性。 日志解读 最前...

  • ##一次CMS GC问题排查过程(理解原理+读懂GC日志)

    一次CMS GC问题排查过程(理解原理+读懂GC日志) - iamzhongyong - ITeye技术网站 h...

  • JVM - GC日志

    JVM - GC日志 -XX:+PrintGC 输出GC日志 -XX:+PrintGCDetails 输出GC的详...

  • 理解JVM GC日志

    一、理解JVM日志 从深入理解JVM书上的例子开始,各个收集器的日志格式不同,但是都维持一定的共性: 33.125...

  • 3.5.8 理解GC日志

    两段GC日志: 33.125:[GC[DefNew:3324K->152K(3712K),0.0025925 se...

  • [JVM]理解GC日志

    深入理解Java虚拟机[JVM]Java内存区域与垃圾收集 - 思维导图[JVM]类加载机制 - 思维导图[JVM...

网友评论

      本文标题:理解GC日志

      本文链接:https://www.haomeiwen.com/subject/thlpwftx.html