虚拟机性能监控、故障处理工具
1、jps:虚拟机进程状态工具
# 列出正在运行的虚拟机进程
[root@iZm5egmklv9cgsnrwuviapZ ~]# jps
31920 demo-0.0.1-SNAPSHOT.jar
3408 Jps
1290 jenkins.war
2、jstat:虚拟机统计信息监视工具
# 它可以显示本地或者远程虚拟机中的类加载、内存、垃圾收集、即时编译等运行时数据。
[root@iZm5egmklv9cgsnrwuviapZ ~]# jstat -gcutil 31920
S0 S1 E O M CCS YGC YGCT FGC FGCT GCT
0.00 0.00 99.43 69.09 95.42 93.33 1054 2.721 3 0.274 2.995
3、jinfo:java配置信息工具
# 实时查看和调整虚拟机各项参数
[root@iZm5egmklv9cgsnrwuviapZ ~]# jinfo -flags 31920
Attaching to process ID 31920, please wait...
Debugger attached successfully.
Server compiler detected.
JVM version is 25.221-b11
Non-default VM flags: -XX:CICompilerCount=2 -XX:InitialHeapSize=31457280 -XX:MaxHeapSize=482344960 -XX:MaxNewSize=160759808 -XX:MinHeapDeltaBytes=196608 -XX:NewSize=10485760 -XX:OldSize=20971520 -XX:+UseCompressedClassPointers -XX:+UseCompressedOops
Command line:
4、jmap:java内存映像工具
# 用于生成堆转储快照(一般称为 heapdump 或 dump 文件)
[root@iZm5egmklv9cgsnrwuviapZ ~]# jmap -F -dump:live,file=heap.bin 31920
[root@iZm5egmklv9cgsnrwuviapZ ~]# jmap -F -histo 31920
[root@iZm5egmklv9cgsnrwuviapZ ~]# jmap -heap 31920
5、jhat:虚拟机堆转储快照分析工具
# 与 jmap 搭配使用,来分析 jmap 生成的堆转储快照。
[root@iZm5egmklv9cgsnrwuviapZ ~]# jhat heap.bin
分析结果默认以包为单位进行分组显示
分析内存泄漏问题主要会使用到其中的”Heap Histogram“与OQL页签的功能,前者可以找到内存中容量最大的对象,后者是标准的对象查询语言,使用类似SQL的语法对内存中的对象进行查询统计。
6、jstack:java堆栈跟踪工具
# 用于生成虚拟机当前时刻的线程快照。线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的目的通常是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间挂起等,都是导致线程长时间停顿的常见原因。线程出现停顿时通过jstack来查看各个线程的调用堆栈,就可以获知没有响应的线程到底在后台做些什么事情,或者等待着什么资源。
[root@iZm5egmklv9cgsnrwuviapZ ~]# jstack -F -l 31920