【深入理解jvm】虚拟机性能监控与故障处理工具
数据:运行日志、异常堆栈、GC日志、线程快照(threaddump/Javacore文件)、堆转储快照(headdump/hrof文件)
jdk的bin目录下的工具大多数是jdk/lib/tools.jar类库的一层薄包装,主要的功能代码是在tools类库中实现
备注:tools.jar中的类库不属于Java的标准API,如果引入这个类库,就意味着用户的程序只能运行于Sun HotSpots上面,或者在部署程序时需要一起部署tools.jar
jdk的监控和故障处理工具:
名称 | 主要作用 |
jps | JVM ProcessStatus 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 Tree for Java 显示虚拟机线程快照 |
1.jps 虚拟机进程状况工具
可以列出正在运行的虚拟机进程,并显示虚拟机执行主类(Main Class,main()函数所在的类)名称以及这些进程的本地虚拟机唯一ID
jps -q 只输出LVMID,省略主类的名称
jps -m 输出虚拟机进程启动时传递给主类main()函数的参数
jps -l 输出主类的全名,如果进程执行的是jar包,输出jar路径
jps -v 输出虚拟机进程启动时显示指定的JVM参数列表
2.jstat 虚拟机统计信息监视工具
它可以显示本地或者远程虚拟机进程中的类装载、内存、垃圾收集、JIT编译等运行数据,是运行期定位虚拟机性能问题的首选工具
命令格式:jstat option vmid interval (ms) count
option代表希望查询的虚拟机信息,主要分为3类:类装载、垃圾收集、运行期编译情况
参数interval 和 count代表查询间隔和次数,如果省略这两个参数,说明只查询一次
如:jstat -gcutil 559 1000 1000 每1秒查询一次进程559垃圾收集情况,一共查询1000次
jstat -class 556 监控类装载、卸载数量,总空间以及类装载所耗费的时间
jstat -gc 556 监控Java堆状况,包括Eden区、两个survivor区、老年代、永久代等的容量,已用空间、GC时间等信息 单位为KB
jstat -gccapacity 556 监控内容与-gc基本相同,但输出主要关注Java堆各个区域使用到的最大、最小空间
jstat -gcutil 556 监控内容与-gc基本相同,但输出主要关注已使用空间占总空间的百分比
jstat -gccause 556 与gcutil 功能一样,但是会额外输出导致上一次GC产生的原因
jstat -gcnew 556 监控新生代GC状况
jstat -gcnewcapacity 556 监控内容与-gcnew基本相同,输出主要关注使用到的最大、最小空间
jstat -gcold 556 监控老生代GC状况
jstat -gcoldcapacity 556 监控内容与-gcold基本相同,输出主要关注使用到的最大、最小空间
jstat -compiler 556 输出JIT编译器编译过的方法、耗时等信息
jstat -printcompilation 556 输出已经被JIT编译的方法
3.jinfo Java配置信息工具
jinfo的作用是实时地查看和调整虚拟机各项参数
想知道未被显示指定的参数的系统默认值,可以使用jinfo的-flag选项(jdk1.6或以上版本,使用Java -XX: +PrintFlagsFinal查看参数默认值)
jinfo [option] pid
jinfo -sysprops 556 把虚拟机进程的System.getProperties()的内容打印出来
4.jmap Java 内存映像工具
jmap的作用:获取dump文件,查询finalize执行队列、Java堆和永久代的详细信息如空间使用率、当前用的是哪种收集器
jmap -dump:[live,]format=b,file=<filename> <pid>
通过-dump选项,把java堆中的对象dump到本地文件,然后使用MAT进行分析。
如果添加了live,只会dump活跃的对象
jmap -dump :live,format=b,file=a.bin 556
把556Java堆中活的对象dump到本地文件a.bin文件中
jmap -finalizerinfo 556 显示在F-Queue中等待Finalizer线程执行finalize方法的对象。只在Linux/Solaris平台下有效
jmap -heap 556 显示Java堆的详细信息,如使用哪种回收器、参数配置、分代状况等。只在Linux/Solaris平台下有效
jmap -histo 556 显示堆中对象统计信息,包括类、实例数量、合计容量
jmap -histo:live 556 统计堆中活的对象数(会触发一次Full GC)
jmap -permstat 556 以ClassLoader为统计口径显示永久代内存状态。只在Linux/Solaris平台下有效
5.jhat 虚拟机堆转储快照分析工具
jhat内置了一个微型HTTP/HTML服务器,生成dump文件的分析结果后,可以在浏览器中查看。
实际中并不常用jhat命令分析dump文件,原因:
一是一般不会再部署应用程序的服务器上直接分析dump文件(因为分析工作是一个耗时而且消耗硬件资源的过程)
二是jhat的分析功能相对来说比较简陋
jhat dump文件名
屏幕显示“Server is ready”的提示后,用户在浏览器中键入http://localhost:7000/ 就可以看到分析结果
6.jstack Java堆栈跟踪工具
jstack 命令用于生成虚拟机当前时刻的线程快照(theaddump或者Javacore文件)
线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的主要目的是定位线程出现长时间停顿的原因,如线程死锁、死循环、请求外部资源导致的长时间等待等都是导致线程长时间停顿的常见原因。
线程出现停顿的时候,通过jstack来查看各个线程的调用堆栈,就可以知道没有响应的线程到底在后台做些什么事情,或者等待着什么资源
jstack -F 556 当正常输出的请求不被响应时,强制输出线程堆栈
jstack -l 556 除堆栈外,显示关于锁的附件信息
jstack -m 556 如果调用到本地方法的话,可以显示C/C++的堆栈