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。
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。
相关文章推荐
- JavaScript中字符串的常用操作汇总
- js实现99乘法表
- 字符串反转_JavaScript
- JS点击按钮弹出窗口
- js中两个感叹号的原理与用法分析
- extjs入门
- javascript编程技巧_模块化编程(匿名函数)
- 写个js程序咖常写的游戏-贪吃蛇
- JSP学生信息管理系统
- 字符串反转_JavaScript
- JavaScript Math 对象常用方法总结
- JavaScript String 对象常用方法总结
- echart js简单封装
- @ResponseBody 获取json转换为本地对象
- json解析
- 格式化方法以及JSON编码和解码
- JS 实现checkbox多选按钮 全选
- JS 获取 格式化日期字符串
- Jsp入门
- 是什么让javascript变得如此奇妙