JVM监控命令总结(jps、jstat、jmap、jhat、jstack)

最近遇到了jvm调优的事情,用到了一些工具(jvisualvm、jconsole),墙裂推荐JProfiler(非免费)。也用到了一些jvm监控命令,遂想总结一下,以备后用。期间参考了不少资料,比如:

https://blog.csdn.net/wisgood/article/details/25343845

一、jps

(Java Virtual Machine Process Status Tool)

jps主要用来输出JVM中运行的进程状态信息。语法格式如下:

jps [options] [hostid]

    如果不指定hostid就默认为当前主机或服务器。

    命令行参数选项说明如下:

  • -q 不输出类名、Jar名和传入main方法的参数
  • -m 输出传入main方法的参数
  • -l 输出main类或Jar的全限名
  • -v 输出传入JVM的参数
C:\>jps -l -m

59476 sun.tools.jps.Jps -l -m

56844 org.apache.catalina.startup.Bootstrap start

 

二、jstat

jstat命令可以查看堆内存各部分的使用量,以及加载类的数量。命令的格式如下:

jstat [-命令选项] [vmid] [间隔时间/毫秒] [查询次数]

(1)、类加载统计:

C:\>jstat -class 56844

Loaded  Bytes    Unloaded  Bytes   Time

3147    6133.6     0        0.0    12.75
  • Loaded:加载class的数量
  • Bytes:所占用空间大小
  • Unloaded:未加载数量
  • Bytes:未加载占用空间
  • Time:时间

(2)、编译统计

C:\>jstat -compiler 56844

Compiled Failed Invalid   Time    FailedType FailedMethod

1698       0      0      10.05       0
  • Compiled:编译数量。
  • Failed:失败数量
  • Invalid:不可用数量
  • Time:时间
  • FailedType:失败类型
  • FailedMethod:失败的方法

(3)、垃圾回收统计

 

C:\>jstat -gc 56844

S0C  S1C  S0U S1U   EC      EU      OC      OU      MC     MU     CCSC    CCSU YGC YGCT FGC FGCT GCT

64.0 64.0 0.0 0.0 65408.0 22430.3 65536.0 13735.8 17792.0 17259.3 2176.0 1978.4  1 0.130 0 0.000 0.130
  • S0C:第一个幸存区的大小
  • S1C:第二个幸存区的大小
  • S0U:第一个幸存区的使用大小
  • S1U:第二个幸存区的使用大小
  • EC:伊甸园区的大小
  • EU:伊甸园区的使用大小
  • OC:老年代大小
  • OU:老年代使用大小
  • MC:方法区大小
  • MU:方法区使用大小
  • CCSC:压缩类空间大小
  • CCSU:压缩类空间使用大小
  • YGC:年轻代垃圾回收次数
  • YGCT:年轻代垃圾回收消耗时间
  • FGC:老年代垃圾回收次数
  • FGCT:老年代垃圾回收消耗时间
  • GCT:垃圾回收消耗总时间

(4)、堆内存统计

C:\>jstat -gccapacity 56844

NGCMN   NGCMX    NGC    S0C  S1C   EC    OGCMN    OGCMX   OGC     OC     MCMN   MCMX      
 MC   CCSMN CCSMX CCSC YGC FGC

65536.0 65536.0 65536.0 64.0 64.0 65408.0 65536.0 65536.0 65536.0 65536.0 0.0 1064960.0 17792.0 0.0 1048576.0 2176.0 1 0
  • NGCMN:新生代最小容量
  • NGCMX:新生代最大容量
  • NGC:当前新生代容量
  • S0C:第一个幸存区大小
  • S1C:第二个幸存区的大小
  • EC:伊甸园区的大小
  • OGCMN:老年代最小容量
  • OGCMX:老年代最大容量
  • OGC:当前老年代大小
  • OC:当前老年代大小
  • MCMN:最小元数据容量
  • MCMX:最大元数据容量
  • MC:当前元数据空间大小
  • CCSMN:最小压缩类空间大小
  • CCSMX:最大压缩类空间大小
  • CCSC:当前压缩类空间大小
  • YGC:年轻代gc次数
  • FGC:老年代GC次数

(5)、新生代垃圾回收统计

C:\>jstat -gcnew 56844

S0C S1C S0U S1U TT MTT DSS EC EU YGC YGCT

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

(6)、新生代内存统计

C:\>jstat -gcnewcapacity 56844

NGCMN NGCMX NGC S0CMX S0C S1CMX S1C ECMX EC YGC FGC

65536.0 65536.0 65536.0 64.0 64.0 64.0 64.0 65408.0 65408.0 1 0
  • NGCMN:新生代最小容量
  • NGCMX:新生代最大容量
  • NGC:当前新生代容量
  • S0CMX:最大幸存1区大小
  • S0C:当前幸存1区大小
  • S1CMX:最大幸存2区大小
  • S1C:当前幸存2区大小
  • ECMX:最大伊甸园区大小
  • EC:当前伊甸园区大小
  • YGC:年轻代垃圾回收次数
  • FGC:老年代回收次数

(7)、老年代垃圾回收统计

C:\>jstat -gcold 56844

MC MU CCSC CCSU OC OU YGC FGC FGCT GCT

17792.0 17259.3 2176.0 1978.4 65536.0 13735.8 1 0 0.000 0.130
  • MC:方法区大小
  • MU:方法区使用大小
  • CCSC:压缩类空间大小
  • CCSU:压缩类空间使用大小
  • OC:老年代大小
  • OU:老年代使用大小
  • YGC:年轻代垃圾回收次数
  • FGC:老年代垃圾回收次数
  • FGCT:老年代垃圾回收消耗时间
  • GCT:垃圾回收消耗总时间

(8)、老年代内存统计

C:\>jstat -gcoldcapacity 56844

OGCMN    OGCMX    OGC      OC    YGC FGC  FGCT  GCT

65536.0 65536.0 65536.0 65536.0   1   0  0.000 0.130
  • OGCMN:老年代最小容量
  • OGCMX:老年代最大容量
  • OGC:当前老年代大小
  • OC:老年代大小
  • YGC:年轻代垃圾回收次数
  • FGC:老年代垃圾回收次数
  • FGCT:老年代垃圾回收消耗时间
  • GCT:垃圾回收消耗总时间

(9)、元数据空间统计

C:\>jstat -gcmetacapacity 56844

MCMN  MCMX     MC    CCSMN CCSMX    CCSC  YGC  FGC  FGCT  GCT

0.0 1064960.0 17792.0 0.0 1048576.0 2176.0 1   0   0.000  0.130
  • MCMN:最小元数据容量
  • MCMX:最大元数据容量
  • MC:当前元数据空间大小
  • CCSMN:最小压缩类空间大小
  • CCSMX:最大压缩类空间大小
  • CCSC:当前压缩类空间大小
  • YGC:年轻代垃圾回收次数
  • FGC:老年代垃圾回收次数
  • FGCT:老年代垃圾回收消耗时间
  • GCT:垃圾回收消耗总时间

(10)、总结垃圾回收统计

C:\>jstat -gcutil 56844

S0    S1   E     O     M    CCS   YGC YGCT  FGC   FGCT    GCT

0.00 0.00 34.29 20.96 97.01 90.92  1  0.130 0    0.000   0.130
  • S0:幸存1区当前使用比例
  • S1:幸存2区当前使用比例
  • E:伊甸园区使用比例
  • O:老年代使用比例
  • M:元数据区使用比例
  • CCS:压缩使用比例
  • YGC:年轻代垃圾回收次数
  • FGC:老年代垃圾回收次数
  • FGCT:老年代垃圾回收消耗时间
  • GCT:垃圾回收消耗总时间

(11)、JVM编译方法统计

C:\>jstat -printcompilation 56844

Compiled Size Type Method

1713 19 1 java/util/concurrent/CopyOnWriteArrayList iterator
  • Compiled:最近编译方法的数量
  • Size:最近编译方法的字节码数量
  • Type:最近编译方法的编译类型。
  • Method:方法名标识。

 

三、jmap

(Memory Map)

JVM Memory Map命令用于生成heap dump文件,如果不使用这个命令,还可以使用-XX:+HeapDumpOnOutOfMemoryError参数来让虚拟机出现OOM的时候自动生成dump文件。 jmap不仅能生成dump文件,还可以查询finalize执行队列、Java堆和永久代的详细信息,如当前使用率、当前使用的是哪种收集器等。

命令格式:

  • jmap [ option ] pid
  • jmap [ option ] executable core
  • jmap [ option ] [server-id@]remote-hostname-or-IP

参数

option:选项参数,不可同时使用多个选项参数

pid:java进程id,命令ps -ef | grep java获取

executable:产生核心dump的java可执行文件

core:需要打印配置信息的核心文件

remote-hostname-or-ip:远程调试的主机名或ip

server-id:可选的唯一id,如果相同的远程主机上运行了多台调试服务器,用此选项参数标识服务器

 

options参数:

  • heap : 显示Java堆详细信息
  • histo : 显示堆中对象的统计信息
  • permstat :Java堆内存的永久保存区域的类加载器的统计信息
  • finalizerinfo : 显示在F-Queue队列等待Finalizer线程执行finalizer方法的对象
  • dump : 生成堆转储快照
  • F : 当-dump没有响应时,强制生成dump快照,此模式下,不支持live子选项。

示例:

C:\>jmap -dump:live,format=b,file=d:/dump.hprof 56844

Dumping heap to D:\dump.hprof ...

Heap dump file created

dump堆到文件,format指定输出格式,live指明是活着的对象,file指定文件名

 

四、jhat

(Java Heap Analysis Tool)

C:\>jhat -port 9998 d:/dump.hprof

Reading from d:/dump.hprof...

Dump file created Fri Sep 28 15:30:55 CST 2018

Snapshot read, resolving...

Resolving 134437 objects...

Chasing references, expect 26 dots..........................

Eliminating duplicate references..........................

Snapshot resolved.

Started HTTP server on port 9998

Server is ready.

然后就可以访问http://localhost:9998查看了。

 

五、jstack

 

jstack主要用来查看某个Java进程内的线程堆栈信息。语法格式如下:

  • jstack [option] pid
  • jstack [option] executable core
  • jstack [option] [server-id@]remote-hostname-or-ip

命令行参数选项说明如下:

  • -l long listings,会打印出额外的锁信息,在发生死锁时可以用jstack -l pid来观察锁持有情况
  • -m mixed mode,不仅会输出Java堆栈信息,还会输出C/C++堆栈信息(比如Native方法)

jstack可以定位到线程堆栈,根据堆栈信息我们可以定位到具体代码,所以它在JVM性能调优中使用得非常多。下面我们来一个实例找出某个Java进程中最耗费CPU的Java线程并定位堆栈信息,用到的命令有ps、top、printf、jstack、grep。

 

1,根据top命令,发现PID为7247的Java进程占用CPU高达300%,出现故障。

JVM监控命令总结(jps、jstat、jmap、jhat、jstack)_第1张图片

2,找到该进程后,如何定位具体线程或代码呢,首先显示线程列表,并按照CPU占用高的线程排序:

[root@localhost /]# ps -mp 7247 -o THREAD,tid,time | sort -rn

显示结果如下:

JVM监控命令总结(jps、jstat、jmap、jhat、jstack)_第2张图片

找到了耗时最高的线程7248,占用CPU时间一个半小时了!

将需要的线程ID转换为16进制格式:

[root@localhost /]# printf "%x\n" 7248

最后打印线程的堆栈信息:

[root@localhost /]# jstack 7247 |grep 1c50 -A 30

JVM监控命令总结(jps、jstat、jmap、jhat、jstack)_第3张图片

再查看ServiceTask.java的第54行,解决了。

 

你可能感兴趣的:(Java)