JDK 命令行工具
运行日志、异常堆栈、GC 日志、线程快照(threaddump/javacore 文件)、堆转储快照(heapdump/hprof 文件)等
名称 | 主要作用 |
---|---|
jps | JVM Process Status Tool,显示制定系统内所有的 HotSpot 虚拟机进程 |
jstat | JVM Statistics Monitoring Tool,用于收集 HotSpot 虚拟机各方面的运行数据 |
jinfo | Configuration Info for Java,显示虚拟机配置信息 |
jmap | Memory Map for Java,生成虚拟机的内存转储快照( heapdump 文件) |
jhat | JVM Heap Dump Browser,用于分析 heapdump 文件,它会建立一个 HTTP/HTML 服务器,让用户可以在浏览器上查看分析结果 |
jstack | Stack Trace for Java,显示虚拟机的线程快照 |
jps:虚拟机进程状况工具
jps [ options] [ hostid ]
选项 | 作用 |
---|---|
-q | 只输出 LVMID,省略主类的名称 |
-m | 输出虚拟机进程启动时传递给主类 main() 函数的参数 |
-l | 输出主类的全名,如果进程执行的是 Jar 包,输出 Jar 路径 |
-v | 输出虚拟机进程启动时 JVM 参数 |
jstat:虚拟机统计信息监视工具
显示虚拟机进程中的类装载、内存、垃圾收集、JIT 编译等运行数据,没有 GUI 图形界面,只提供了纯文本控制台环境等服务器上,是运行期定位虚拟机性能问题的首选工具
命令格式:
jstat [ option vmid [interval [ s | ms ] [ count ] ] ]
如果是本地虚拟机进程,VMID 和 LVMID 是一致的;如果是远程虚拟机主机,那 VMID 的格式应当是:
[ protocol : ] [ // ] lvmid [ @hostname [ :port ] / servername ]
参数 interval 和 count 代表查询间隔和次数,如果省略这两个参数,说明只查询一次。
比如,每250毫秒查询一次进程2764垃圾收集情况,一共查询20次:
jstat -gc 2764 250 20
选项 option 代表用户希望查询的虚拟机信息,主要分3类:类装载、垃圾收集、运行期编译情况
选项 | 作用 |
---|---|
-class | 监视类装载、卸载数量、总空间以及类装载所耗费的时间 |
-gc | 监视 Java 堆状况,包括 Eden 区、两个 survivor 区、老年代、永久代等的容量、已用空间、GC 时间合计等信息 |
-gccapacity | 监视内容与 -gc 基本相同,但输出主要关注 Java 堆各个区域使用到的最大、最小空间 |
-gcutil | 监视内容与 -gc 基本相同,但输出主要关注已使用空间占总空间的百分比 |
-gacause | 与 -gcutil 功能一样,但是会额外输出导致上一次 GC 产生的原因 |
-gcnew | 监视新生代 GC 状况 |
-gcnewcapacity | 监视内容与 -gcnew 基本相同,输出主要关注使用到的最大、最小空间 |
-gcold | 监视老年代 GC 状况 |
-gcpermcapacity | 监视内容与 -gcold 基本相同,输出主要关注使用到的最大、最小空间 |
-compiler | 输出 JIT 编译器编译过的方法、耗时等信息 |
-printcompilation | 输出已经被 JIT 编译的方法 |
jinfo:Java 配置信息工具
实时地查看和调整虚拟机各项参数
命令格式:
jinfo [ option ] pid
jmap:Java 内存映像工具
用于生成堆转储快照( 一般称 heapdump 或 dump 文件)
命令格式:
jmap [ option ] vmid
选项 | 作用 |
---|---|
-dump | 生成 Java 堆转储快照,格式为:-dump:[live, ]format=b, file= |
-finalizerinfo | 显示在 F-Queue 中等待 Finalizer 线程执行 finalize 方法的对象。只在 Linux/Solaris 平台下有效 |
-heap | 显示 Java 堆详细信息,如使用哪种回收器、参数配置、分代状况等。只在 Linux/Solaris 平台下有效 |
-histo | 显示堆中对象统计信息,包括类、实例数量、合计容量 |
-permstat | 以 ClassLoader 为统计口径显示永久代内存状态。只在 Linux/Solaris 平台下有效 |
-F | 当虚拟机进程对 -dump 选项没有响应时,可使用这个选项强制生成 dump 快照。只在 Linux/Solaris 平台下有效 |
jhat:虚拟机堆转储快照分析工具
jhat 和 jmap 搭配使用,来分析 jmap 生成的堆转储快照。jhat 内置一个微型的 HTTP/HTML 服务器,生成 dump 文件的分析结果后,可以在浏览器中查看。一般不会使用 jhat 命令分析 dump 文件,原因有二:
- 一般不会在部署应用程序的服务器上直接分析 dump 文件,因为分析工作是一个耗时且耗硬件资源的过程
- jhat 的分析功能相对简陋,VisulaVM、专业分析 dump 文件的 Eclipse Memory Analyzer、IBM HeapAnalyzer等工具的分析功能更专业
jstack:Java 堆栈跟踪工具
生成虚拟机当前时刻的线程快照(一般称为 threaddump 或者 javacore 文件)。
线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的主要目的是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等
命令格式:
jstack [ option ] vmid
选项 | 作用 |
---|---|
-F | 当正常输出的请求不被响应时,强制输出线程堆栈 |
-l | 除堆栈外,显示关于锁的附加信息 |
-m | 如果调用到本地方法的话,可以显示 C/C++ 的堆栈 |
JDK 的可视化工具
JConsole:Java 监视与管理控制台
基于 JMX 的可视化监视、管理工具
启动 JConsole:JDK/bin 目录下的 “jconsole.ext”
VisualVM:多合一故障处理工具
除了运行监视、故障处理外,还提供其他功能,如性能分析。不需要被监视的程序基于特殊 Agent 运行,因此 VisualVM 对应用程序的实际性能的影响很小,使得它可以直接应用在生产环境中。
VisualVM 基于 NetBeans 平台开发,具备插件扩展功能,通过插件扩展支持,VisualVM 可以做到:
- 显示虚拟机进程以及进程的配置、环境信息(jps、jinfo)
- 监视应用程序的 CPU、GC、堆、方法区以及线程的信息(jstat、jstack)
- dump 以及分析堆转储快照(jmap、jhat)
- 方法级的程序运行性能分析,找出被调用最多、运行时间最长的方法
- 离线程序快照:收集程序的运行时配置、线程 dump、内存 dump 等信息建立一个快照,可以将快照发送开发者出进行 Bug 反馈
- 其他 plugins 的无限的可能性