loong - Java 命令 - jstat

loong - Java - 命令 - jstat

jstat命令用于监视Java应用程序的性能。它可以使用不同的选项打印出Java虚拟机(JVM)中各个内部组件的性能统计数据

基本语法

jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]

参数说明

  • options:jstat命令提供了多个选项来控制输出的内容和格式。可以使用jstat -options查看所有选项及其说明。
  • -t: 可以在打印的列加上Timestamp列,用于显示系统运行的时间
  • -h: 可以在周期性数据数据的时候,可以在指定输出多少行以后输出一次表头
  • vmid(pid):正在运行的Java进程ID(可以使用jps命令获取)。
  • interval:可选参数,指定两次采样之间的时间间隔(以毫秒为单位)。如果省略,则默认为1秒。
  • count:可选参数,指定采样次数。如果省略,则默认为无限次。

常见选项

  • -class 显示ClassLoad的相关信息;
  • -compiler 显示JIT编译的相关信息;
  • -gc 显示和gc相关的堆信息;
  • -gccapacity    显示各个代的容量以及使用情况;
  • -gcmetacapacity 显示metaspace的大小
  • -gcnew 显示新生代信息;
  • -gcnewcapacity 显示新生代大小和使用情况;
  • -gcold 显示老年代和永久代的信息;
  • -gcoldcapacity 显示老年代的大小;
  • -gcutil   显示垃圾收集信息;
  • -gccause 显示垃圾回收的相关信息(通-gcutil),同时显示最后一次或当前正在发生的垃圾回收的诱因;
  • -printcompilation 输出JIT编译的方法信息;

使用案例

jstat -class [pid]

显示加载class的数量,及所占空间等信息。

jstat -class [pid]

内容说明

  • Loaded : 已经装载的类的数量
  • Bytes : 装载类所占用的字节数
  • Unloaded:已经卸载类的数量
  • Bytes:卸载类的字节数
  • Time:装载和卸载类所花费的时间

示例

D:\loong-log\a\b>jstat -class 8832
Loaded  Bytes  Unloaded  Bytes     Time
  9975 17390.5        0     0.0       3.26

jstat -compiler [pid]

显示VM实时编译(JIT)的数量等信息。

jstat -compiler [pid]

内容说明

  • Compiled:编译任务执行数量
  • Failed:编译任务执行失败数量
  • Invalid :编译任务执行失效数量
  • Time :编译任务消耗时间
  • FailedType:最后一个编译失败任务的类型
  • FailedMethod:最后一个编译失败任务所在的类及方法

示例

D:\loong-log\a\b>jstat -compiler 8832 2 3
Compiled Failed Invalid   Time   FailedType FailedMethod
    4677      1       0     0.86          1 sun/misc/ProxyGenerator generateClassFile
    4677      1       0     0.86          1 sun/misc/ProxyGenerator generateClassFile
    4677      1       0     0.86          1 sun/misc/ProxyGenerator generateClassFile

jstat -gc [pid]

显示gc相关的堆信息,查看gc的次数,及时间。

jstat –gc [pid]

内容说明

  • S0C:年轻代中第一个survivor(幸存区)的容量 (字节)
  • S1C:年轻代中第二个survivor(幸存区)的容量 (字节)
  • S0U :年轻代中第一个survivor(幸存区)目前已使用空间 (字节)
  • S1U :年轻代中第二个survivor(幸存区)目前已使用空间 (字节)
  • EC :年轻代中Eden(伊甸园)的容量 (字节)
  • EU :年轻代中Eden(伊甸园)目前已使用空间 (字节)
  • OC :Old代的容量 (字节)
  • OU :Old代目前已使用空间 (字节)
  • MC:metaspace(元空间)的容量 (字节)
  • MU:metaspace(元空间)目前已使用空间 (字节)
  • YGC :从应用程序启动到采样时年轻代中gc次数
  • YGCT :从应用程序启动到采样时年轻代中gc所用时间(s)
  • FGC :从应用程序启动到采样时old代(全gc)gc次数
  • FGCT :从应用程序启动到采样时old代(全gc)gc所用时间(s)
  • GCT:从应用程序启动到采样时gc用的总时间(s)

示例

D:\loong-log\a\b>jstat -gc 8832
 S0C    S1C    S0U    S1U      EC       EU        OC         OU       MC     MU    CCSC   CCSU   YGC     YGCT    FGC    FGCT     GCT
32256.0 10752.0  0.0    0.0   254976.0 213873.7  761344.0   58706.7   35496.0 33743.6 5040.0 4611.6      3    0.038   2      0.219    0.257

jstat -gccapacity [pid]

可以显示,VM内存中三代(young,old,perm)对象的使用和占用大小

jstat -gccapacity [pid]

内容说明

  • 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次数

示例

D:\loong-log\a\b>jstat -gccapacity 8832
 NGCMN    NGCMX     NGC     S0C   S1C       EC      OGCMN      OGCMX       OGC         OC       MCMN     MCMX      MC     CCSMN    CCSMX     CCSC    YGC    FGC
261120.0 4172800.0 425984.0 32256.0 10752.0 254976.0   523264.0  8346624.0   761344.0   761344.0      0.0 1079296.0  35496.0      0.0 1048576.0   5040.0      3     2

jstat -gcmetacapacity [pid]

metaspace 中对象的信息及其占用量。

jstat -gcmetacapacity[pid]

内容说明

  • MCMN:最小元数据容量
  • MCMX:最大元数据容量
  • MC:当前元数据空间大小
  • CCSMN:最小压缩类空间大小
  • CCSMX:最大压缩类空间大小
  • CCSC:当前压缩类空间大小
  • YGC :从应用程序启动到采样时年轻代中gc次数
  • FGC :从应用程序启动到采样时old代(全gc)gc次数
  • FGCT :从应用程序启动到采样时old代(全gc)gc所用时间(s)
  • GCT:从应用程序启动到采样时gc用的总时间(s)

示例

D:\loong-log\a\b>jstat -gcmetacapacity 8832
   MCMN       MCMX        MC       CCSMN      CCSMX       CCSC     YGC   FGC    FGCT     GCT
       0.0  1079296.0    35496.0        0.0  1048576.0     5040.0     3     2    0.219    0.257

jstat -gcnewcapcity [pid]

年轻代对象的信息及其占用量

jstat -gcnewcapacity <pid>

内容说明

  • NGCMN :年轻代(young)中初始化(最小)的大小(字节)
  • NGCMX :年轻代(young)的最大容量 (字节)
  • NGC :年轻代(young)中当前的容量 (字节)
  • S0CMX :年轻代中第一个survivor(幸存区)的最大容量 (字节)
  • S0C :年轻代中第一个survivor(幸存区)的容量 (字节)
  • S1CMX :年轻代中第二个survivor(幸存区)的最大容量 (字节)
  • S1C:年轻代中第二个survivor(幸存区)的容量 (字节)
  • ECMX:年轻代中Eden(伊甸园)的最大容量 (字节)
  • EC:年轻代中Eden(伊甸园)的容量 (字节)
  • YGC:从应用程序启动到采样时年轻代中gc次数
  • FGC:从应用程序启动到采样时old代(全gc)gc次数

示例

D:\loong-log\a\b>jstat -gcnewcapacity 8832
  NGCMN      NGCMX       NGC      S0CMX     S0C     S1CMX     S1C       ECMX        EC      YGC   FGC
  261120.0  4172800.0   425984.0 1390592.0  32256.0 1390592.0  10752.0  4171776.0   254976.0     3     2

jstat -gcold [pid]

old代对象的信息

jstat -gcold <pid>

内容说明

  • MC :metaspace(元空间)的容量 (字节)
  • MU:metaspace(元空间)目前已使用空间 (字节)
  • CCSC:压缩类空间大小
  • CCSU:压缩类空间使用大小
  • OC:Old代的容量 (字节)
  • OU:Old代目前已使用空间 (字节)
  • YGC:从应用程序启动到采样时年轻代中gc次数
  • FGC:从应用程序启动到采样时old代(全gc)gc次数
  • FGCT:从应用程序启动到采样时old代(全gc)gc所用时间(s)
  • GCT:从应用程序启动到采样时gc用的总时间(s)

示例

D:\loong-log\a\b>jstat -gcold 8832
   MC       MU      CCSC     CCSU       OC          OU       YGC    FGC    FGCT     GCT
 35496.0  33743.6   5040.0   4611.6    761344.0     58706.7      3     2    0.219    0.257

jstat -gcoldcapacity [pid]

old代对象的信息及其占用量

jstat -gcoldcapacity <pid>

内容说明

  • OGCMN :old代中初始化(最小)的大小 (字节)
  • OGCMX :old代的最大容量(字节)
  • OGC :old代当前新生成的容量 (字节)
  • OC :Old代的容量 (字节)
  • YGC :从应用程序启动到采样时年轻代中gc次数
  • FGC :从应用程序启动到采样时old代(全gc)gc次数
  • FGCT :从应用程序启动到采样时old代(全gc)gc所用时间(s)
  • GCT:从应用程序启动到采样时gc用的总时间(s)

示例

D:\loong-log\a\b>jstat -gcoldcapacity 8832
   OGCMN       OGCMX        OGC         OC       YGC   FGC    FGCT     GCT
   523264.0   8346624.0    761344.0    761344.0     3     2    0.219    0.257

jstat -gcutil [pid]

统计gc信息

jstat -gcutil <pid>

内容说明

  • S0 :年轻代中第一个survivor(幸存区)已使用的占当前容量百分比
  • S1 :年轻代中第二个survivor(幸存区)已使用的占当前容量百分比
  • E :年轻代中Eden(伊甸园)已使用的占当前容量百分比
  • O :old代已使用的占当前容量百分比
  • P :perm代已使用的占当前容量百分比
  • YGC :从应用程序启动到采样时年轻代中gc次数
  • YGCT :从应用程序启动到采样时年轻代中gc所用时间(s)
  • FGC :从应用程序启动到采样时old代(全gc)gc次数
  • FGCT :从应用程序启动到采样时old代(全gc)gc所用时间(s)
  • GCT:从应用程序启动到采样时gc用的总时间(s)

示例

D:\loong-log\a\b>jstat -gcutil 8832
  S0     S1     E      O      M     CCS    YGC     YGCT    FGC    FGCT     GCT
  0.00   0.00  88.58   7.71  95.06  91.50      3    0.038     2    0.219    0.257

jstat -gccause [pid]

显示垃圾回收的相关信息(通-gcutil),同时显示最后一次或当前正在发生的垃圾回收的诱因。

jstat -gccause <pid>

内容说明

  • LGCC:最后一次GC原因
  • GCC:当前GC原因(No GC 为当前没有执行GC)

示例

D:\loong-log\a\b>jstat -gccause 8832
  S0     S1     E      O      M     CCS    YGC     YGCT    FGC    FGCT     GCT    LGCC                 GCC
  0.00   0.00  88.58   7.71  95.06  91.50      3    0.038     2    0.219    0.257 Metadata GC Threshold No GC

jstat -printcompilation [pid]

当前VM执行的信息。

jstat -printcompilation <pid>

内容说明

  • Compiled :编译任务的数目
  • Size :方法生成的字节码的大小
  • Type:编译类型
  • Method:类名和方法名用来标识编译的方法。类名使用/做为一个命名空间分隔符。方法名是给定类中的方法。上述格式是由-XX:+PrintComplation选项进行设置的

示例

D:\loong-log\a\b>jstat -printcompilation 8832
Compiled  Size  Type Method
    4722    195    1 java/util/concurrent/locks/AbstractQueuedSynchronizer doAcquireInterruptibly
  • 10
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

7-Moon

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值