持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第3天,点击查看活动详情
前言
前面介绍了性能调优命令,jstack和jmap 分别查看堆栈线程快照和内存快照,jstat命令可以查看堆内存各部分的使用量,以及加载类的数量。
1、jstat命令简介
Jstat是JDK自带的一个轻量级小工具。它位于java的bin目录下,主要利用内建的指令对Java应用程序的资源和性能进行实时的命令行的监控,包括了对Heap size和垃圾回收状况的监控。
基本语法:
jstat [-命令选项] [vmid] [间隔时间/毫秒] [查询次数] \
1.1 jstat -help 基本用法
[app@dzopdev-010010195187 ~]$ jstat -help
Usage: jstat -help|-options
jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]
Definitions:
<option> An option reported by the -options option
<vmid> Virtual Machine Identifier. A vmid takes the following form:
<lvmid>[@<hostname>[:<port>]]
Where <lvmid> is the local vm identifier for the target
Java virtual machine, typically a process id; <hostname> is
the name of the host running the target Java virtual machine;
and <port> is the port number for the rmiregistry on the
target host. See the jvmstat documentation for a more complete
description of the Virtual Machine Identifier.
<lines> Number of samples between header lines.
<interval> Sampling interval. The following forms are allowed:
<n>["ms"|"s"]
Where <n> is an integer and the suffix specifies the units as
milliseconds("ms") or seconds("s"). The default units are "ms".
<count> Number of samples to take before terminating.
-J<flag> Pass <flag> directly to the runtime system.
[app@dzopdev-010010195187 ~]$
-t:可以在打印的列加上Timestamp列,用于显示系统运行的时间
-h:可以在周期性数据输出的时候,指定输出多少行以后输出一次表头
vmid:Virtual Machine ID( 进程的 pid)
interval:执行每次的间隔时间,单位为毫秒
count:用于指定输出多少次记录,缺省则会一直打印
2、option
jstat -options 参数命令
[app@dzopdev-010010195187 ~]$ jstat -options
-class 用于查看类加载情况的统计
-compiler 用于查看HotSpot中即时编译器编译情况的统计
-gc 用于查看JVM中堆的垃圾收集情况的统计
-gccapacity 用于查看新生代、老生代及持久代的存储容量情况
-gccause 显示[垃圾回收]的相关信息(同-gcutil),同时显示最后一次仅当前正在发生的垃圾收集的原因
-gcmetacapacity 用于查看新生代垃圾收集的情况
-gcnew 用于查看新生代存储容量的情况
-gcnewcapacity 用于查看老生代及持久代垃圾收集的情况
-gcold 用于查看老生代及持久代垃圾收集的情况
-gcoldcapacity 用于查看老生代的容量
-gcutil 显示垃圾收集信息
-printcompilation 输出JIT编译的方法信息
[app@dzopdev-010010195187 ~]$
2.1 -class
用于查看类加载情况的统计
[app@dzopdev-010010195187 ~]$ jstat -class 6770
Loaded Bytes Unloaded Bytes Time
12693 22220.5 182 234.8 585.04
[app@dzopdev-010010195187 ~]$
Loaded:加载类的数量
Bytes:加载类的size,单位为Byte
Unloaded:卸载类的数目
Bytes:卸载类的size,单位为Byte
Time:加载与卸载类花费的时间
2.2 -compiler
用于查看HotSpot中即时编译器编译情况的统计
[app@dzopdev-010010195187 ~]$ jstat -compiler 6770
Compiled Failed Invalid Time FailedType FailedMethod
15576 12 0 794.07 1 com/alibaba/fastjson/parser/deserializer/JavaBeanDeserializer deserialze
[app@dzopdev-010010195187 ~]$
Compiled:编译任务执行数量
Failed:编译任务执行失败数量
Invalid:编译任务执行失效数量
Time:编译任务消耗时间
FailedType:最后一个编译失败任务的类型
FailedMethod:最后一个编译失败任务所在的类及方法
2.3 -gc
用于查看JVM中堆的垃圾收集情况的统计
[app@dzopdev-010010195187 ~]$ jstat -gc 6770
S0C S1C S0U S1U EC EU OC OU MC MU CCSC CCSU YGC YGCT FGC FGCT GCT
2048.0 2048.0 1238.3 0.0 170496.0 162438.5 349696.0 38520.3 70528.0 66534.7 8832.0 8120.4 17200 218.988 5 24.557 243.545
[app@dzopdev-010010195187 ~]$
S0C:年轻代中第一个survivor(幸存区)的容量 (字节)
S1C:年轻代中第二个survivor(幸存区)的容量 (字节)
S0U:年轻代中第一个survivor(幸存区)目前已使用空间 (字节)
S1U:年轻代中第二个survivor(幸存区)目前已使用空间 (字节)
EC:年轻代中Eden(伊甸园)的容量 (字节)
EU:年轻代中Eden(伊甸园)目前已使用空间 (字节)
OC:Old代的容量 (字节)
OU:Old代目前已使用空间 (字节)
MC:metaspace(元空间)的容量 (字节)
MU:metaspace(元空间)目前已使用空间 (字节)
CCSC:当前压缩类空间的容量 (字节)
CCSU:当前压缩类空间目前已使用空间 (字节)
YGC:从应用程序启动到采样时年轻代中gc次数
YGCT:从应用程序启动到采样时年轻代中gc所用时间(s)
FGC:从应用程序启动到采样时old代(全gc)gc次数
FGCT:从应用程序启动到采样时old代(全gc)gc所用时间(s)
GCT:从应用程序启动到采样时gc用的总时间(s) \
2.5 -gccapacity
用于查看新生代、老生代及持久代的存储容量情况
[app@dzopdev-010010195187 ~]$ jstat -gccapacity 6770
NGCMN NGCMX NGC S0C S1C EC OGCMN OGCMX OGC OC MCMN MCMX MC CCSMN CCSMX CCSC YGC FGC
174592.0 174592.0 174592.0 2048.0 2048.0 170496.0 349696.0 349696.0 349696.0 349696.0 0.0 1112064.0 70528.0 0.0 1048576.0 8832.0 17202 5
[app@dzopdev-010010195187 ~]$
NGCMN:年轻代(young)中初始化(最小)的大小(字节)
NGCMX:年轻代(young)的最大容量 (字节)
NGC:年轻代(young)中当前的容量 (字节)
S0C:年轻代中第一个survivor(幸存区)的容量 (字节)
S1C:年轻代中第二个survivor(幸存区)的容量 (字节)
EC:年轻代中Eden(伊甸园)的容量 (字节)
OGCMN:old代中初始化(最小)的大小 (字节)
OGCMX:old代的最大容量(字节)
OGC:old代当前新生成的容量 (字节)
OC:Old代的容量 (字节)
MCMN:metaspace(元空间)中初始化(最小)的大小 (字节)
MCMX:metaspace(元空间)的最大容量 (字节)
MC:metaspace(元空间)当前新生成的容量 (字节)
CCSMN:最小压缩类空间大小
CCSMX:最大压缩类空间大小
CCSC:当前压缩类空间大小
YGC:从应用程序启动到采样时年轻代中gc次数
FGC:从应用程序启动到采样时old代(全gc)gc次数
2.6 -gcmetacapacity
元数据空间统计
[app@dzopdev-010010195187 ~]$ jstat -gcmetacapacity 6770
MCMN MCMX MC CCSMN CCSMX CCSC YGC FGC FGCT GCT
0.0 1112064.0 70528.0 0.0 1048576.0 8832.0 17203 5 24.557 243.572
[app@dzopdev-010010195187 ~]$
MCMN:最小元数据容量
MCMX:最大元数据容量
MC:当前元数据空间大小
CCSMN:最小压缩类空间大小
CCSMX:最大压缩类空间大小
CCSC:当前压缩类空间大小
YGC:从应用程序启动到采样时年轻代中gc次数
FGC:从应用程序启动到采样时old代(全gc)gc次数
FGCT:从应用程序启动到采样时old代(全gc)gc所用时间(s)
GCT:从应用程序启动到采样时gc用的总时间(s)
2.7 -gcnew
新生代垃圾回收统计
[app@dzopdev-010010195187 ~]$ jstat -gcnew 6770
S0C S1C S0U S1U TT MTT DSS EC EU YGC YGCT
2048.0 2048.0 1526.4 0.0 15 15 2048.0 170496.0 17711.4 17204 219.021
[app@dzopdev-010010195187 ~]$
S0C:年轻代中第一个survivor(幸存区)的容量 (字节)
S1C:年轻代中第二个survivor(幸存区)的容量 (字节)
S0U:年轻代中第一个survivor(幸存区)目前已使用空间 (字节)
S1U:年轻代中第二个survivor(幸存区)目前已使用空间 (字节)
TT:持有次数限制
MTT:最大持有次数限制
DSS:期望的幸存区大小
EC:年轻代中Eden(伊甸园)的容量 (字节)
EU:年轻代中Eden(伊甸园)目前已使用空间 (字节)
YGC:从应用程序启动到采样时年轻代中gc次数
YGCT:从应用程序启动到采样时年轻代中gc所用时间(s)
2.8 -gcnewcapacity
新生代内存统计
[app@dzopdev-010010195187 ~]$ jstat -gcnewcapacity 6770
NGCMN NGCMX NGC S0CMX S0C S1CMX S1C ECMX EC YGC FGC
174592.0 174592.0 174592.0 57856.0 2048.0 57856.0 2048.0 173568.0 170496.0 17204 5
[app@dzopdev-010010195187 ~]$
NGCMN:年轻代(young)中初始化(最小)的大小(字节)
NGCMX:年轻代(young)的最大容量 (字节)
NGC:年轻代(young)中当前的容量 (字节)
S0CMX:年轻代中第一个survivor(幸存区)的最大容量 (字节)
S0C:年轻代中第一个survivor(幸存区)的容量 (字节)
S1CMX:年轻代中第二个survivor(幸存区)的最大容量 (字节)
S1C:年轻代中第二个survivor(幸存区)的容量 (字节)
ECMX:年轻代中Eden(伊甸园)的最大容量 (字节)
EC:年轻代中Eden(伊甸园)的容量 (字节)
YGC:从应用程序启动到采样时年轻代中gc次数
FGC:从应用程序启动到采样时old代(全gc)gc次数
2.9 -gcold
[app@dzopdev-010010195187 ~]$ jstat -gcold 6770
MC MU CCSC CCSU OC OU YGC FGC FGCT GCT
70528.0 66534.7 8832.0 8120.4 349696.0 38592.3 17205 5 24.557 243.586
[app@dzopdev-010010195187 ~]$
MC:metaspace(元空间)的容量 (字节) MU:metaspace(元空间)目前已使用空间 (字节) CCSC:压缩类空间大小 CCSU:压缩类空间使用大小 OC:Old代的容量 (字节) OU:Old代目前已使用空间 (字节) YGC:从应用程序启动到采样时年轻代中gc次数 FGC:从应用程序启动到采样时old代(全gc)gc次数 FGCT:从应用程序启动到采样时old代(全gc)gc所用时间(s) GCT:从应用程序启动到采样时gc用的总时间(s)
2.10 -gcoldcapacity
[app@dzopdev-010010195187 ~]$ jstat -gcoldcapacity 6770
OGCMN OGCMX OGC OC YGC FGC FGCT GCT
349696.0 349696.0 349696.0 349696.0 17205 5 24.557 243.586
[app@dzopdev-010010195187 ~]$
OGCMN:old代中初始化(最小)的大小 (字节)
OGCMX:old代的最大容量(字节)
OGC:old代当前新生成的容量 (字节)
OC:Old代的容量 (字节)
YGC:从应用程序启动到采样时年轻代中gc次数
FGC:从应用程序启动到采样时old代(全gc)gc次数
FGCT:从应用程序启动到采样时old代(全gc)gc所用时间(s)
GCT:从应用程序启动到采样时gc用的总时间(s)
2.11 -gcutil
垃圾回收统计
[app@dzopdev-010010195187 ~]$ jstat -gcutil 6770
S0 S1 E O M CCS YGC YGCT FGC FGCT GCT
72.18 0.00 52.03 11.04 94.34 91.94 17206 219.038 5 24.557 243.596
[app@dzopdev-010010195187 ~]$
S0:年轻代中第一个survivor(幸存区)已使用的占当前容量百分比
S1:年轻代中第二个survivor(幸存区)已使用的占当前容量百分比
E:年轻代中Eden(伊甸园)已使用的占当前容量百分比
O:old代已使用的占当前容量百分比
M:元数据区已使用的占当前容量百分比
CCS:压缩类空间已使用的占当前容量百分比
YGC :从应用程序启动到采样时年轻代中gc次数
YGCT :从应用程序启动到采样时年轻代中gc所用时间(s)
FGC :从应用程序启动到采样时old代(全gc)gc次数
FGCT :从应用程序启动到采样时old代(全gc)gc所用时间(s)
GCT:从应用程序启动到采样时gc用的总时间(s) \
2.12 -gccause
显示垃圾回收的相关信息(同-gcutil),同时显示最后一次或当前正在发生的垃圾回收的原因
[app@dzopdev-010010195187 ~]$ jstat -gccause 6770
S0 S1 E O M CCS YGC YGCT FGC FGCT GCT LGCC GCC
72.18 0.00 81.27 11.04 94.34 91.94 17206 219.038 5 24.557 243.596 Allocation Failure No GC
[app@dzopdev-010010195187 ~]$
LGCC:最后一次GC原因
GCC:当前GC原因(No GC 为当前没有执行GC)
2.13 -printcompilation
JVM编译方法统计
[app@dzopdev-010010195187 ~]$ jstat -printcompilation 6770
Compiled Size Type Method
15576 400 1 sun/misc/FloatingDecimal getBinaryToASCIIConverter
[app@dzopdev-010010195187 ~]$
Compiled:编译任务的数目
Size:方法生成的字节码的大小
Type:编译类型
Method:类名和方法名用来标识编译的方法。类名使用/做为一个命名空间分隔符,方法名是给定类中的方法。上述格式是由-XX:+PrintComplation选项进行设置的
3、 常用命令举例
jstat -gc 6770 200 10 查看进程6770 gc情况,间隔200ms, 打印10次
[app@dzopdev-010010195187 ~]$ jstat -gc 6770 200 10
S0C S1C S0U S1U EC EU OC OU MC MU CCSC CCSU YGC YGCT FGC FGCT GCT
2048.0 2048.0 0.0 1382.3 170496.0 118567.5 349696.0 38624.3 70528.0 66534.7 8832.0 8120.4 17209 219.068 5 24.557 243.625
2048.0 2048.0 0.0 1382.3 170496.0 119533.9 349696.0 38624.3 70528.0 66534.7 8832.0 8120.4 17209 219.068 5 24.557 243.625
2048.0 2048.0 0.0 1382.3 170496.0 119533.9 349696.0 38624.3 70528.0 66534.7 8832.0 8120.4 17209 219.068 5 24.557 243.625
2048.0 2048.0 0.0 1382.3 170496.0 119536.0 349696.0 38624.3 70528.0 66534.7 8832.0 8120.4 17209 219.068 5 24.557 243.625
2048.0 2048.0 0.0 1382.3 170496.0 119540.1 349696.0 38624.3 70528.0 66534.7 8832.0 8120.4 17209 219.068 5 24.557 243.625
2048.0 2048.0 0.0 1382.3 170496.0 119567.6 349696.0 38624.3 70528.0 66534.7 8832.0 8120.4 17209 219.068 5 24.557 243.625
2048.0 2048.0 0.0 1382.3 170496.0 119569.6 349696.0 38624.3 70528.0 66534.7 8832.0 8120.4 17209 219.068 5 24.557 243.625
2048.0 2048.0 0.0 1382.3 170496.0 119569.6 349696.0 38624.3 70528.0 66534.7 8832.0 8120.4 17209 219.068 5 24.557 243.625
2048.0 2048.0 0.0 1382.3 170496.0 119569.6 349696.0 38624.3 70528.0 66534.7 8832.0 8120.4 17209 219.068 5 24.557 243.625
2048.0 2048.0 0.0 1382.3 170496.0 119736.3 349696.0 38624.3 70528.0 66534.7 8832.0 8120.4 17209 219.068 5 24.557 243.625
[app@dzopdev-010010195187 ~]$
总结
jstat 功能对于gc分析很全面,但是现在生产的应用微服务应用动辄就是几十台服务器,靠这个命令分析还是十分困难的,不管对于小公司或者大公司生产上服务的稳定性保障和监控都是必要的。当然jstat也是我们jvm调优分析的利器。