jstat查看gc情况

您所在的位置:网站首页 gcutil分析 jstat查看gc情况

jstat查看gc情况

#jstat查看gc情况| 来源: 网络整理| 查看: 265

jstat通常用来分析系统的垃圾回收情况。

1)命令:

jstat -gccause pid 2000     #每格2秒输出结果

jstat -gcutil pid  2000

jstat查看gc情况_java

2)分析:

S0、S1 代表两个Survivor区;E 代表 Eden 区;O(Old)代表老年代;P(Permanent)代表永久代;YGC(Young GC)代表Minor GC;YGCT代表Minor GC耗时;FGC(Full GC)代表Full GC耗时;GCT代表Minor & Full GC共计耗时。

Java 堆分为新生代和老年代,新生代一般划分为三块区域,Eden + From Survivor + To Survivor,Eden 和 Survivor 的内存比为8:1,每次只使用一个Eden 和一个 Survivor 区域,另一个Survivor 用于复制收集算法回收内存。

jstat查看gc情况_老年代_02

对象一般尽量分配到新生代中,而对于大对象(长字符串和大数组)直接分配在老年代中,同时“年龄”长的的对象会从新生代自动晋升到老年代中。

 

Java 方法区称为永久代,只有 HotSpot 虚拟机才存在永久代。

 

首先想eden区申请分配空间,如果空间够,就直接进行分配,否则进行一次Minor GC。minor GC 首先会对Eden区的对象进行标记,标记出来存活的对象。然后把存活的对象copy到From空间。如果From空间足够,则回收eden区可回收的对象。如果from内存空间不够,则把From空间存活的对象复制到To区,如果TO区的内存空间也不够的话,则把To区存活的对象复制到老年代。如果老年代空间也不够(或者达到触发老年年垃圾回收条件的话)则触发一次full GC。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3