【Java】JDK Tools and Utilities
JDK Tools and Utilities
JDK
提供了一系列工具给开发者使用
这里介绍一些常用,其他部分可参考官网
LIST:
- Basic Tools: jar,javap
- Java Troubleshooting, Profiling, Monitoring and Management Tools:jcmd
- Monitoring Tools: jps,jstat
- Troubleshooting Tools: jinfo,jstack,jhat,jmap
Basic Tools
jar
1 | ```bash |
javap
1 | # -c 对代码进行反编译,-l 输出行号和本地变量表 |
Java Troubleshooting, Profiling, Monitoring and Management Tools
jcmd
1 |
|
Monitoring Tools
jps
jps(JVM Process Status Tool)
可以列出正在运行的虚拟机进程,并显示虚拟机执行主类(Main Class,main()函数所在的类)
名称以及这些进程的本地虚拟机唯一ID(Local Virtual Machine Identifier,LVMID)
。
虽然功能比较单一,但它是使用频率最高的JDK命令行工具,因为其他的JDK工具大多需要输入它查询到的LVMID来确定要监控的是哪一个虚拟机进程。
对于本地虚拟机进程来说,LVMID与操作系统的进程ID(Process Identifier,PID)是一致的,使用Windows的任务管理器或者UNIX的ps命令也可以查询到虚拟机进程的LVMID,但如果同时启动了多个虚拟机进程,无法根据进程名称定位时,那就只能依赖jps命令显示主类的功能才能区分了。
1 | # 命令格式 |
jstat
jstat(JVM statistics Monitoring)
是用于监视虚拟机运行时状态信息的命令,它可以显示出虚拟机进程中的类装载、内存、垃圾收集、JIT编译等运行数据。
1 | # 命令格式 |
Troubleshooting Tools
jinfo
jinfo(JVM Configuration info)
这个命令作用是实时查看和调整虚拟机运行参数。
之前的jps -v
口令只能查看到显示指定的参数,如果想要查看未被显示指定的参数的值就要使用jinfo
口令
1 |
|
jmap
jmap(Memory Map for Java)
命令用于生成堆转储快照(一般称为heapdump或dump文件)。
如果不使用jmap命令,要想获取Java堆转储快照,还有一些比较“暴力”的手段:譬如加-XX:+HeapDumpOnOutOfMemoryError
参数,可以让虚拟机在OOM异常出现之后自动生成dump文件,通过-XX:+HeapDumpOnCtrlBreak
参数则可以使用[Ctrl]+[Break]键让虚拟机生成dump文件,又或者在Linux系统下通过Kill-3
命令发送进程退出信号“吓唬”一下虚拟机,也能拿到dump文件。
jmap的作用并不仅仅是为了获取dump文件,它还可以查询finalize执行队列、Java堆和永久代的详细信息,如空间使用率、当前用的是哪种收集器等。和jinfo命令一样,jmap有不少功能在Windows平台下都是受限的,除了生成dump文件的-dump选项和用于查看每个类的实例、空间占用统计的-histo选项在所有操作系统都提供之外,其余选项都只能在Linux/Solaris下使用。
1 | # 用法 |
jhat
jhat(JVM Heap Analysis Tool)命令与jmap搭配使用,来分析jmap生成的堆转储快照。jhat内置了一个微型的HTTP/HTML服务器,生成dump文件的分析结果后,可以在浏览器中查看。
1 | # 格式 |
jstack
jstack(Stack Trace for Java)命令用于生成虚拟机当前时刻的线程快照(一般称为threaddump或者javacore文件)。
线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的主要目的是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等都是导致线程长时间停顿的常见原因。
线程出现停顿的时候通过jstack来查看各个线程的调用堆栈,就可以知道没有响应的线程到底在后台做些什么事情,或者等待着什么资源。
1 | # 查询当前线程快照 |