虚拟机基础故障处理工具

JDK的bin目录下有一些用于监视虚拟机运行状态和进行故障处理的工具,
可以分为三类:

  • 商业授权工具
    • 主要是JMC以及它使用到的JFR
  • 正式支持工具
    • 这类工具属于被长期支持的工具,不同平台、不同版本的JDK之间,这类工具会有差异,但是不会出现某个工具突然消失的情况。
  • 实验性工具
    • 这类工具没有技术支持,是实验性质的,未来可能会转正也可能会消失,但它们通常都非常稳定而且功能强大,也能处理应用程序的性能问题、定位故障。

这些工具大多数体积都异常小,21k左右
因为这些命令行工具大多是一层薄包装,
真正的功能代码是实现在JDK的工具类库中的


jps:虚拟机进程状况工具

JDK的很多小工具命名都参考了UNIX命名方式,如jps(JVM Process Status Tool)

功能:
可以列出正在运行的虚拟机进程,并显示虚拟机执行主类(Main Class, main()函数所在的类)名称以及这些进程的本地虚拟机唯一ID(LVMID)

虽然功能比较单一,但它是使用频率最高的JDK命令行工具
因为其他JDK工具大多数需要输入它查询到的LVMID来确定要监控的是哪一个虚拟机进程。
对于本地虚拟机进程来说,LVMID与操作系统的进程ID(PID)是一致的,使用Windows的任务管理器或者UNIX的ps命令也可以查询到虚拟机进程的LVMID,
但如果同时启动了多个虚拟机进程,无法根据进程名称定位时,
那就必须依赖jps命令显示主类的功能才能区分。

jps还可以通过RMI协议查询开启了RMI服务的远程虚拟机进程状态


jstat:虚拟机统计信息监控工具

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


jinfo:Java配置信息工具

jinfo(Configuration Info for Java)的作用是实时查看和调整虚拟机各项参数。


jmap:Java内存映像工具

jmap(Memory Map for java)命令用于生成堆转储快照(一般称为heapdump或者dump文件)
还可以查询finalize执行队列、Java堆和方法区的详细信息,如空间使用率、当前用的是哪种收集器等。


jhat:虚拟机堆转储快照分析工具

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

正常不使用这个工具


jstack:Java堆栈跟踪工具

jstack(Stack Trace for Java)命令用于生成虚拟机当前时刻的线程快照(一般称为threaddump或者javacore文件)

线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的目的通常是定位线程出现长时间停顿的原因
如线程间死锁、死循环、请求外部资源导致长时间的挂起等,都是导致线程长时间停顿的常见原因。

线程出现停顿时通过jstack来查看各个线程的调用堆栈,就可以知道没有响应的线程到底在后台做些什么事情,或者是在等待什么资源

posted @ 2021-01-31 20:17  张三丰学Java  阅读(152)  评论(0编辑  收藏  举报