jstat

作者: a丶逍遥子 | 来源:发表于2020-03-09 20:34 被阅读0次

用户收集HotSpot虚拟机各方面的运行数据

jstat -help

Usage: jstat -help|-options
jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]
option: 参数选项
-t: 可以在打印的列加上Timestamp列,用于显示系统运行的时间
-h: 可以在周期性数据数据的时候,可以在指定输出多少行以后输出一次表头
vmid: Virtual Machine ID( 进程的 pid)
interval: 执行每次的间隔时间,单位为毫秒
count: 用于指定输出多少次记录,缺省则会一直打印

jstat -options

-class 监视类装载、卸载数量、总空间及类装载所耗时间
-compiler 输出JIT编译器编译过的方法、耗时等信息
-gc 监视Java堆状况
-gccapacity 显示各个代的容量以及使用情况
-gccause 显示垃圾回收的相关信息(通-gcutil),同时显示最后一次或当前正在发生的垃圾回收的诱因
-gcmetacapacity 显示metaspace的大小
-gcnew 显示新生代信息
-gcnewcapacity 显示新生代大小和使用情况
-gcold 显示老年代和永久代的信息
-gcoldcapacity 显示老年代的大小
-gcutil 显示垃圾收集信息
-printcompilation 输出JIT编译的方法信息

实例一: -class

  • 监视类装载、卸载数量、总空间及类装载所耗时间
jstat -class 13317
Loaded  Bytes  Unloaded  Bytes     Time   
  1825  3542.3        0     0.0       0.29
  • Loaded : 已经装载的类的数量
  • Bytes : 装载类所占用的字节数
  • Unloaded:已经卸载类的数量
  • Bytes:未加载占用空间
  • Time:装载和卸载类所花费的时间

示例二: -compiler

  • 输出JIT编译器编译过的方法、耗时等信息
jstat -compiler 13317
Compiled Failed Invalid   Time   FailedType FailedMethod  
   996      0    0        0.60          0  
  • Compiled:编译任务执行数量
  • Failed:编译任务执行失败数量
  • Invalid :编译任务执行失效数量
  • Time :编译任务消耗时间
  • FailedType:最后一个编译失败任务的类型
  • FailedMethod:最后一个编译失败任务所在的类及方法

示例三: -gc

  • -gc 监视Java堆状况
jstat -gc 12280
 S0C    S1C    S0U    S1U      EC       EU        OC         OU       MC     MU    CCSC   CCSU   YGC     YGCT    FGC    FGCT     GCT   
 0.0    0.0    0.0    0.0   19456.0   3072.0   25600.0     9964.8   24064.0 23307.9 2816.0 2589.1      2    0.012   1      0.015    0.027

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)

实例三:-gccapacity

  • 显示各个代的容量以及使用情况
jstat -gccapacity 13317
 NGCMN    NGCMX     NGC     S0C   S1C       EC      OGCMN      OGCMX       OGC         OC       MCMN     MCMX      MC     CCSMN    CCSMX     CCSC    YGC    FGC 
 84992.0 1357824.0  84992.0 10240.0 10240.0  64512.0   171008.0  2715648.0   171008.0   171008.0      0.0 1058816.0  11648.0      0.0 1048576.0   1408.0      2     2

NGCMN:年轻代(young)中初始化(最小)的大小(字节)
NGCMX:年轻代(young)的最大容量 (字节)
NGC:年轻代(young)中当前的容量 (字节)
S0C:第一个幸存区大小
S1C:第二个幸存区的大小
EC:伊甸园区的大小
OGCMN:old代中初始化(最小)的大小 (字节)
OGCMX:老年代最大容量
OGC:当前老年代大小
OC:当前老年代大小
MCMN:最小元数据容量
MCMX:最大元数据容量
MC:当前元数据空间大小
CCSMN:最小压缩类空间大小
CCSMX:最大压缩类空间大小
CCSC:当前压缩类空间大小
YGC:年轻代gc次数
FGC:老年代GC次数

实例三:-gcutil

  • 显示垃圾收集信息
jstat -gcutil 13317
  S0     S1     E      O      M     CCS    YGC     YGCT    FGC    FGCT     GCT   
  0.00   0.00  11.39   2.92  95.75  86.17      2    0.022     2    0.067    0.089

S0 第一个幸存区
S1 第二个幸存区
E 伊甸园区
O 老年代
M 元空间
CCS 压缩类空间
YGC 年轻代GC次数
YGCT 年轻代耗时
FGC FullGC次数
FGCT FullGC总耗时
GCT GC总耗时

实例四:-gcnew

  • 显示新生代信息
jstat -gcnew 13317
 S0C    S1C    S0U    S1U   TT MTT  DSS      EC       EU     YGC     YGCT  
10240.0 10240.0    0.0    0.0  7  15 10240.0  64512.0   8208.3      2    0.022

S0C:第一个幸存区大小
S1C:第二个幸存区的大小
S0U:第一个幸存区的使用大小
S1U:第二个幸存区的使用大小
TT:对象在新生代存活的次数
MTT:对象在新生代存活的最大次数
DSS:期望的幸存区大小
EC:伊甸园区的大小
EU:伊甸园区的使用大小
YGC:年轻代垃圾回收次数
YGCT:年轻代垃圾回收消耗时间

实例四:-gcold

  • 显示新生代信息
jjstat -gcold 13317
   MC       MU      CCSC     CCSU       OC          OU       YGC    FGC    FGCT     GCT   
 11648.0  11152.9   1408.0   1213.3    171008.0      4990.5      2     2    0.067    0.089

相关文章

网友评论

      本文标题:jstat

      本文链接:https://www.haomeiwen.com/subject/sfflyctx.html