您的位置:首页 > Web前端 > JavaScript

jstat查看gc情况

2016-04-28 09:17 567 查看
jstat通常用来分析系统的垃圾回收情况。

1)命令:

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



jstat -gcutil pid  2000



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
用于复制收集算法回收内存。



对象一般尽量分配到新生代中,而对于大对象(长字符串和大数组)直接分配在老年代中,同时“年龄”长的的对象会从新生代自动晋升到老年代中。
 
Java
方法区称为永久代,只有 HotSpot
虚拟机才存在永久代。
 

首先想eden区申请分配空间,如果空间够,就直接进行分配,否则进行一次Minor
GC。minor GC
首先会对Eden区的对象进行标记,标记出来存活的对象。然后把存活的对象copy到From空间。如果From空间足够,则回收eden区可回收的对象。如果from内存空间不够,则把From空间存活的对象复制到To区,如果TO区的内存空间也不够的话,则把To区存活的对象复制到老年代。如果老年代空间也不够(或者达到触发老年年垃圾回收条件的话)则触发一次full
GC。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: