目录

Life in Flow

知不知,尚矣;不知知,病矣。
不知不知,殆矣。

X

虚拟机工具

虚拟机工具的作用

 使用适当的虚拟机监控和分析的工具可以加快我们分析数据、定位解决问题的速度。
 需要分析的数据包括:运行日志、异常堆栈、GC 日志、线程快照
( threaddump/javacore文件)、堆转储快照( heapdump/hprof文件)等。

虚拟机工具JPS

 jps (JVM Process Status Tool)是其中的典型jvm工具。除了名字像 UNIX 的 ps 命令之外,它的功能也和 ps 命令类似:可以列出正在运行的虚拟机进程,并显示虚拟机执行主类(Main Class, main()函数所在的类)名称以及这些进程的本地虚拟机唯- ID (Local Virtual Machine Identifier, LVMID),虽然功能比较单一,但它是使用频率最高的 JDK 命令行工具

-l	#展示类全限定名,如果进程执行的是Jar包则输出Jar路径。
-v	#输出虚拟机进程启动时JVM参数

C:\Users\soulboy>jps
10488
7944 DemoApplication
1740 Jps
2252 Launcher
4988 RemoteMavenServer

虚拟机工具jstat与jinfo

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

 jstat -gc 2764 250 20   //2764表示进程id ,250表示250毫秒打印一次 ,20表示一共打印20次

 S0C:第一个幸存区的大小 Survivor from
 S1C:第二个幸存区的大小 Survivor to
 S0U:第一个幸存区的使用大小
 S1U:第二个幸存区的使用大小
 EC:伊甸园区的大小
 EU:伊甸园区的使用大小
 OC:老年代大小
 OU:老年代使用大小
 MC:方法区大小
 MU:方法区使用大小
 CCSC:压缩类空间大小
 CCSU:压缩类空间使用大小
 YGC:年轻代垃圾回收次数
 YGCT:年轻代垃圾回收消耗时间
 FGC:老年代垃圾回收次数
 FGCT:老年代垃圾回收消耗时间
 GCT:垃圾回收消耗总时间

jinfo
 jinfo (Configuration Info for Java)的作用是实时地查看和调整虚拟机各项参数。使用 jps 命令的-v 参数可以查看虚拟机启动时显式指定的参数列表,但如果想知道未被显式指定的参数的系统默认值,除了去找资料外,就只能使用 jinfo 的-flag 选项进行查询了。

C:\Users\soulboy>jinfo 7944

虚拟机工具jmap

 Jmap (Memory Map for Java)命令用于生成堆转储快照
 如果不使用 jmap 命令,要想获取 Java 堆转储快照,还有一些比较“暴力”的手段:-XX: +HeapDumpOnOutOfMemoryError 参数,可以让虚拟机在 OOM 异常出现之后自动生成 dump 文件,用于系统复盘环节
 和 info 命令一样,jmap 有不少功能在 Windows 平台下都是受限的,除了生成 dump 文件的- dump 选项和用于查看每个类的实例、空间占用统计的-histo选项在所有操作系统都提供之外,其余选项都只能在Linux/Solaris 下使用。
jmap常用命令

# -dump 生成Java堆转储快照。格式: -dump:format=b,file=文件路径\文件名
windows: jmap -dump:format=b,file=d:\a.bin  7944
unix:      jmap -dump:format=b,file=/Users/daniel/deskTop

# -histo more分页去查看:显示堆中对象统计信息,包括类、实例数量、合计容量.
jmap -histo 7944
	B :byte
	C : char
	I :Int

虚拟机工具jhat


Sun JDK 提供 jhat (JVM Heap Analysis Tool)命令常与 jmap 搭配使用,来分析 jmap 生成的堆 转储快照。jhat内置了一个微型的HTTP/HTML服务器,生成dump文件的分析结果后,可以在浏览器中查看。

特点

  • jhat分析工作是一个耗时而且消耗硬件资源的过程
  • jhat 的分析功能相对来说比较简陋

模拟OOM

public class OOMErrorTest {
    public static void main(String[] args) {
        String name = "soulboy";
        for (int i = 0; i < 1000000000; i++) {
            name += name;
        }
    }
}

设置JVM启动参数

-Xmx20m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=d:\

# OOM之后自动dump生成快照文件
java_pid1836.hprof

使用jhat进行分析

C:\Users\soulboy>jhat d:/java_pid1836.hprof
Reading from d:/java_pid1836.hprof...
Dump file created Sun Aug 11 07:45:28 CST 2019
Snapshot read, resolving...
Resolving 10601 objects...
Chasing references, expect 2 dots..
Eliminating duplicate references..
Snapshot resolved.
Started HTTP server on port 7000
Server is ready.

# 访问http://localhost:7000
*   [Show heap histogram](http://localhost:7000/histo/)
*   [Execute Object Query Language (OQL) query](http://localhost:7000/oql/)

虚拟机工具jstack

 Jstack (Stack Trace for Java)命令用于生成虚拟机当前时刻的线程快照(-般称为 threaddump 或者 javacore 文件)。
线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的主要目的是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等都是导致线程长时间停顿的常见原因。线程出现停顿的时候通过 jstack 来查看各个线程的调用堆栈,就可以知道没有响应的线程到底在后台做些什么事情,或者等待着什么资源。

jstack经常用来死锁

C:\Users\soulboy>jstack -l 14820

作者:Soulboy