JVM的监控工具之jstat

参考博客:http://www.javashuo.com/article/p-kclaiqxv-ex.htmlhtml

 

jstat(JVMStatisticsMonitoringTool)是用于监视虚拟机各类运行状态信息的命令行工具。它能够显示本地或者远程虚拟机进程中的类装载、内存、垃圾收集、JIT编译等运行数据,
在没有GUI图形界面,只提供了纯文本控制台环境的服务器上,它将是运行期定位虚拟机性能问题的首选工具。服务器

执行jstat的命令:咱们能够看到能够跟[option],选项option表明着用户但愿查询的虚拟机信息,主要分为3类:类装载、垃圾收集、运行期编译情况。能够跟VMID(惟一进程号),再跟interval和count表明查询间隔和次数,
若是省略这两个参说明只查询一次。ide

 

假设须要每250毫秒查询一次进程idea进程为40416垃圾收集情况,一共查询20次,那命令应当是: jstat  -gc  17312 250 20  工具

 

执行结果中能够看出,S0C表明是Survivor0区,S1C表明是Survivor1区,C表明是容量的意思,U表明是已使用的意思,EC表明Eden区的容量,EU表明Eden区的使用。OC表明老年代的容量,OU表明老年代的使用。
M表明元数据空间。CCSC和CCSU表明的是压缩类的容量大小和压缩类的使用空间大小,YGC的次数,YGCT回收年轻代所需的时间。FGC表明的是Full GC的次数,FGCT表明Full GC的时间,GCT表明垃圾回收整个的时间。性能

 

jstat -options idea

 

能够列出当前JVM版本支持的选项,常见的有命令行

 

l  class (类加载器) 3d

l  compiler (JIT) htm

l  gc (GC堆状态) 对象

l  gccapacity (各区大小) 

l  gccause (最近一次GC统计和缘由) 

l  gcnew (新区统计)

l  gcnewcapacity (新区大小)

l  gcold (老区统计)

l  gcoldcapacity (老区大小)

l  gcpermcapacity (永久区大小)

l  gcutil (GC统计汇总)

l  printcompilation (HotSpot编译统计)

 

查看进程id为17312 的加载类信息 :jstat -class 17312

显示列名   具体描述

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

查看gc发生的缘由:

jstat -gccause 17312  250 20

 

能够看出当前进程最近一段时间内没有发生过GC

 

假如咱们来监测新生代,jstat -gcnew 17312  250 20  这个命令就只会列出和新生代相关的部分。

能够看到老年代 相关的属性再也不展现

 

假如咱们来监测老年代, jstat -gcold 17312  250 20  这个命令就只会列出和老年代相关的部分。

能够看到年轻代的相关属性再也不展现

 

 jstat -compiler <pid>显示VM实时编译的数量等信息。

 

显示列名 具体描述
Compiled 编译任务执行数量
Failed 编译任务执行失败数量
Invalid 编译任务执行失效数量
Time 编译任务消耗时间
FailedType 最后一个编译失败任务的类型
FailedMethod 最后一个编译失败任务所在的类及方法

 

jstat -gccapacity <pid>:能够显示,VM内存中三代(young,old,perm)对象的使用和占用大小

显示列名 具体描述
NGCMN 年轻代(young)中初始化(最小)的大小(字节)
NGCMX 年轻代(young)的最大容量 (字节)
NGC 年轻代(young)中当前的容量 (字节)
S0C 年轻代中第一个survivor(幸存区)的容量 (字节)
S1C 年轻代中第二个survivor(幸存区)的容量 (字节)
EC 年轻代中Eden(伊甸园)的容量 (字节)
OGCMN old代中初始化(最小)的大小 (字节)
OGCMX old代的最大容量(字节)
OGC old代当前新生成的容量 (字节)
OC Old代的容量 (字节)
PGCMN perm代中初始化(最小)的大小 (字节)
PGCMX perm代的最大容量 (字节)
PGC perm代当前新生成的容量 (字节)
PC Perm(持久代)的容量 (字节)
YGC 从应用程序启动到采样时年轻代中gc次数
FGC 从应用程序启动到采样时old代(全gc)gc次数

 

jstat -gcutil <pid>:统计gc信息

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)

相关文章
相关标签/搜索