jstat命令查看jvm的GC情况 (以Linux为例)
jstat命令查看jvm的GC情况 (以Linux为例)
命令格式:
jstat [-命令选项] [vmid] [间隔时间/毫秒] [查询次数]
GC统计概览
jstat -gcutil 30514
字段解释:
- S0:幸存1区当前使用比例
- S1:幸存2区当前使用比例
- E:伊甸园区使用比例
- O:老年代使用比例
- M:元数据区使用比例
- CCS:压缩使用比例
- YGC:年轻代垃圾回收次数
- FGC:老年代垃圾回收次数
- FGCT:老年代垃圾回收消耗时间
- GCT:垃圾回收消耗总时间
GC及jvm内存使用情况
#查看进程30514的GC及jvm内存使用情况,每隔3000ms输出一次,持续输出30次。
jstat -gc 30514 3000 30
字段解释:
- S0C :第一个幸存区的大小
- S1C :第二个幸存区的大小
- S0U :第一个幸存区的已使用大小
- S1U :第二个幸存区的已使用大小
- EC :伊甸园区的大小
- EU :伊甸园区的已使用大小
- OC :老年代大小
- OU :老年代已使用大小
- MC :方法区大小
- MU :方法区已使用大小
- CCSC:压缩类空间大小
- CCSU:压缩类空间已使用大小
- YGC :年轻代垃圾回收次数
- YGCT:年轻代垃圾回收消耗时间
- FGC :老年代垃圾回收次数
- FGCT:老年代垃圾回收消耗时间
- GCT :垃圾回收消耗总时间
堆内存统计
jstat -gccapacity 30514
字段解释:
- NGCMN:新生代最小容量
- NGCMX:新生代最大容量
- NGC:当前新生代容量
- S0C:第一个幸存区大小
- S1C:第二个幸存区的大小
- EC:伊甸园区的大小
- OGCMN:老年代最小容量
- OGCMX:老年代最大容量
- OGC:当前老年代大小
- OC:当前老年代大小
- MCMN:最小元数据容量
- MCMX:最大元数据容量
- MC:当前元数据空间大小
- CCSMN:最小压缩类空间大小
- CCSMX:最大压缩类空间大小
- CCSC:当前压缩类空间大小
- YGC:年轻代gc次数
- FGC:老年代GC次数
新生代垃圾回收统计
jstat -gcnew 30514
字段解释:
- S0C :第一个幸存区的大小
- S1C :第二个幸存区的大小
- S0U :第一个幸存区的已使用大小
- S1U :第二个幸存区的已使用大小
- TT :对象在新生代存活的次数
- MTT :对象在新生代存活的最大次数
- DSS :期望的幸存区大小(期望是新生代的1/10,上面示例中S0C比DSS大一倍,是因为我设置了每块幸存区占新生代的2/10)
- EC :伊甸园区的大小
- EU :伊甸园区的已使用大小
- YGC :年轻代垃圾回收次数
- YGCT:年轻代垃圾回收消耗时间
新生代内存统计
jstat -gcnewcapacity 30514
字段解释:
- NGCMN:新生代最小容量
- NGCMX:新生代最大容量
- NGC:当前新生代容量
- S0CMX:最大幸存1区大小
- S0C:当前幸存1区大小
- S1CMX:最大幸存2区大小
- S1C:当前幸存2区大小
- ECMX:最大伊甸园区大小
- EC:当前伊甸园区大小
- YGC:年轻代垃圾回收次数
- FGC:老年代回收次数
老年代垃圾回收统计
jstat -gcold 30514
字段解释:
- MC:方法区大小
- MU:方法区使用大小
- CCSC:压缩类空间大小
- CCSU:压缩类空间使用大小
- OC:老年代大小
- OU:老年代使用大小
- YGC:年轻代垃圾回收次数
- FGC:老年代垃圾回收次数
- FGCT:老年代垃圾回收消耗时间
- GCT:垃圾回收消耗总时间
老年代内存统计
jstat -gcoldcapacity 30514
字段解释:
- OGCMN:老年代最小容量
- OGCMX:老年代最大容量
- OGC:当前老年代大小
- OC:老年代大小
- YGC:年轻代垃圾回收次数
- FGC:老年代垃圾回收次数
- FGCT:老年代垃圾回收消耗时间
- GCT:垃圾回收消耗总时间
元数据空间统计
jstat -gcmetacapacity 30514
字段解释:
- MCMN: 最小元数据容量
- MCMX:最大元数据容量
- MC:当前元数据空间大小
- CCSMN:最小压缩类空间大小
- CCSMX:最大压缩类空间大小
- CCSC:当前压缩类空间大小
- YGC:年轻代垃圾回收次数
- FGC:老年代垃圾回收次数
- FGCT:老年代垃圾回收消耗时间
- GCT:垃圾回收消耗总时间
类加载统计
jstat -class 30514
字段解释:
- Loaded:加载class的数量
- Bytes:所占用空间大小
- Unloaded:未加载数量
- Bytes:未加载占用空间
- Time:时间
编译统计
jstat -compiler 30514
字段解释:
- Compiled:编译数量
- Failed:失败数量
- Invalid:不可用数量
- Time:时间
- FailedType:失败类型
- FailedMethod:失败的方法
JVM编译方法统计
jstat -printcompilation 30514
字段解释:
- Compiled:最近编译方法的数量
- Size:最近编译方法的字节码数量
- Type:最近编译方法的编译类型
- Method:方法名标识。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!