- 4.1 概述
- 知识、经验是关键基础
- 数据是依据
- 运行日志
- 异常堆栈
- GC日志
- 线程快照(threaddump/javacore文件)
- 堆转储快照(heapdump/hprof文件)
- …
- 工具是运用知识处 理数据的手段
- 4.2 JDK的命令行工具
几乎所有工具的体积基本上 都稳定在27KB左右。是因 为这些命令行工具大多数是jdk/lib/tools.jar类库的一层薄包装而已,它们主要的功能代码是 在tools类库中实现的。
- 4.2.1 jps:虚拟机进程状况工具
-
- 4.2.2 jstat:虚拟机统计信息监视工具
jstat[option vmid[interval[s|ms][count]]]
远程VMID格式:
[protocol:][//]lvmid[@hostname[:port]/servername]-
- 4.2.3 jinfo:Java配置信息工具
jinfo(Configuration Info for Java)的作用是实时地查看和调整虚拟机各项参数。
- C:\>jinfo-flag CMSInitiatingOccupancyFraction 1444
-XX:CMSInitiatingOccupancyFraction=85
- 4.2.4 jmap:Java内存映像工具
jmap的作用并不仅仅是为了获取dump文件,它还可以查询finalize执行队列、Java堆和永 久代的详细信息,如空间使用率、当前用的是哪种收集器等。
- -XX:+HeapDumpOnOutOfMemoryError参数,可以让虚拟机在OOM异常出 现之后自动生成dump文件
- jmap-dump:format=b,file=eclipse.bin 3500
- 4.2.5 jhat:虚拟机堆转储快照分析工具
jhat(JVM Heap Analysis Tool)命令与jmap搭配使用,来分析jmap生成的堆 转储快照。jhat内置了一个微型的HTTP/HTML服务器,生成dump文件的分析结果后,可以在 浏览器中查看。
- 4.2.6 jstack:Java堆栈跟踪工具
jstack(Stack Trace for Java)命令用于生成虚拟机当前时刻的线程快照(一般称为 threaddump或者javacore文件)。线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈 的集合,生成线程快照的主要目的是定位线程出现长时间停顿的原因,如线程间死锁、死循 环、请求外部资源导致的长时间等待等都是导致线程长时间停顿的常见原因。
-
- 4.2.7 HSDIS:JIT生成代码反汇编
- 4.3 JDK的可视化工具
- 4.3.1 JConsole:Java监视与管理控制台
- 概览
- 内存
- 线程
- 类
- VM概要
- 4.3.2 VisualVM:多合一故障处理工具
- 生成、分析堆转储文件
- 性能分析
- 插件……
虚拟机性能监控与故障处理工具
2017.09.20Comments