灵魂拷问,JDK 提供的命令,除了 java、javac,你还用过哪些命令呢?

灵魂再拷问,若你写的 Java 程序,出现了性能问题,该怎么去排查呢?

Java 作为编程语言中的战斗机,JDK 默认已经为我们提供了很多排查问题的工具,接下来就逐一认识认识。

1. jps

jps 命令,可以列出系统中所有运行 Java 进程,并可以查看 Java 进程的启动类、传入参数以及 JVM 参数等信息。

例如,在控制台输入 jps -lmv 命令,效果如下(截取部分内容)。




如何用java实现多选效果 java单选_如何用java实现多选效果


很显然,jps 背后是一个 Java 程序,列出了完整的类路径、传给 main 方法的参数,以及 JVM 的参数。

为了方便了解、查阅,对 jps 命令的参数进行大致的梳理。


如何用java实现多选效果 java单选_JVM_02


另外,不要大惊小怪,jps 以及下面要提到的 JDK 的排查工具,本质都是 Java 程序。

2. jstat

jstat 命令,用于查看 Java 进程的堆使用情况以及 GC 情况。

例如,输出 Java 进程 90961 的类加载相关信息,每秒钟统计一次信息,一共输出 3 次。

控制台输入命令:jstat -class 90961 1000 3,效果如下。


如何用java实现多选效果 java单选_控制台输入_03


如何用java实现多选效果 java单选_控制台输入_04


例如,显示 GC 相关的堆信息。

控制台输入命令:jstat -gc 90961,效果如下。


如何用java实现多选效果 java单选_Java_05


如何用java实现多选效果 java单选_控制台输入_06


例如,显示最近一次 GC 的原因及当前 GC 的原因。

控制台输入命令:jstat -gccause 90961,效果如下。


如何用java实现多选效果 java单选_Java_07


参数含义解释:LGCC:上次 GC 的原因;GCC:当前 GC 的原因。

另外,为了方便了解、查阅,对 jstat 命令的参数进行大致的梳理。


如何用java实现多选效果 java单选_如何用java实现多选效果_08


3. jinfo

jinfo 命令,可以帮我们查看正在运行的 Java 进程的扩展参数,并支持在运行时修改部分参数;可以很方便地帮我们找到 JVM 参数的当前值。

例如,查看 Java 进程 90961 是否开启打印 GC 详细信息。

命令:jinfo -flag PrintGCDetails 90961

例如,打开 Java 进程 90961 的 PrintGCDetails 开关。

命令:jinfo -flag +PrintGCDetails 90961

例如,关闭 Java 进程 90961 的 PrintGCDetails 开关。

命令:jinfo -flag -PrintGCDetails 90961

使用比较简单,就不贴效果啦。

另外,为了方便了解、查阅,对 jinfo 命令的参数也进行大致的梳理。


如何用java实现多选效果 java单选_JVM_09


4. jmap

jmap 命令,可以帮我们生成 Java 进程的堆快照和对象的统计信息。

例如,生成 PID 为 90961 的 Java 进程的对象统计信息,并输出到 yyxj.txt 文件中。

控制台输入命令:jmap -histo 90961 > yyxj.txt,打开文件效果如下。


如何用java实现多选效果 java单选_Java_10


例如,生成 PID 为 90961 的 Java 进程的当前堆快照,输出到 heap.hprof 文件中。

命令:jmap -dump:format=b,file=heap.hprof 90961

对于输出的 heap.hprof 快照文件,可以使用 jhat、VisualVM 等工具打开查看。采用 VisualVM 工具查看,效果如下。


如何用java实现多选效果 java单选_java输出单选框被选信息_11


5. jhat

jhat 命令,用于分析 Java 程序的堆快照内容,并且在分析完成之后,启动一个 HTTP 服务,让我们可以通过浏览器查看 Java 堆快照信息。

例如,采用 jhat 分析上一步中 jmap 输出的堆快照文件。

输入命令:jhat heap.hprof,效果如下。


如何用java实现多选效果 java单选_Java_12


浏览器访问 http://127.0.0.1:7000,一探究竟。


如何用java实现多选效果 java单选_控制台输入_13


另外,唯恐堆快照会比较大,jhat 还支持 OQL 语句查询堆快照信息,闲暇之余可参考帮助手册 http://127.0.0.1:7000/oqlhelp/ 进行深入了解。

6. jstack

jstack 命令,可以帮助我们导出 Java 程序的线程堆栈,并自动帮我们进行死锁检查,并输出找到的死锁信息。

例如,把 PID 为 92760 的 Java 进程的线程堆栈信息,输出保存到文件中。

命令:jstack -l 92760 > deadlock.txt,打开 deadlock.txt,进程的内部细节,一览无余,那么我们很容易,就能找到死锁。


如何用java实现多选效果 java单选_JVM_14


如何用java实现多选效果 java单选_java输出单选框被选信息_15


7. 其它

本次提到的这些命令,建议有时间实操一遍,因为纸上得来终觉浅,绝知此事要躬行

JDK 提供的排查问题的命令还有很多,时间关系,本次就不再一一列举。

后续会进行实战分析,看看如何把这些命令组合起来,去打一套好的组合拳出来,敬请期待。