名称 | 功能 |
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 ,建立http服务器,分析dump文件,并在浏览器中查看 |
jstack | Stack Trace for Java ,显示虚拟机的快照 |
jps
jps:虚拟机进程状态工具,例:
jps -l
jps通过RMI协议查询开启了RMI服务的远程虚拟机进程状态
jstat
监控虚拟机各种状态信息,例:
jstat -gc 1234 1000 10
查询指定进程id(可以通过jps查看)1234,每1000毫秒GC情况,共执行10次
jinfo
实时查看和调整虚拟机的各项参数,例:
jinfo -flag PrintGC 45224
jmap
java内存映射工具,生成堆栈转储快照,不适用jmap命令,可以通过
-XX:+HeapDumpOnOutOfMemoryError
让虚拟机在OOM出现后,自动生成dump文件,并通过
-XX:HeapDumpPath=/path/logs/
指定dump文件的生成目录,
-XX:+HeapDumpOnCtrlBreak
通过ctrl+break组合键让虚拟机生成dump文件,
通过完成命令,生成dump文件,例:
jmap -dump:live format=b,file=/path/logs/heapdump.bin 1234
其中自参数live表示只查看存活对象,1234是通过jps查看到的id
jhat
dump快照分析工具
jhat -port 5000 /path/logs/heapdump.bin
指定http端口,并将分析结果通过http服务器,在浏览器中查看,其中Heap Histogram(类似 jmap -histo)是内存泄漏问题的主要集中点,不建议在生产环境中直接运行命令进行dump文件分析,因为分析过程可能会占用大量的系统资源,另外一个分析工具 visualVM。
jstack
生产虚拟机当前线程的快照(threaddump)
jstack -l 1234
查看指定线程1234堆栈情况,分析线程长时间停留的原因,如线程间死锁,资源等待,停顿。可以通过jstack追踪问题。
tips:
1) java.lang.Thread 类在1.5以后,新增getAllStackTraces()方法,用于获取虚拟机所有线程的StackTraceElement对象,通过该方法完成jstack的大部分功能,实际应用可以通过此方法生成一个简单的jsp页面,查看监控实时信息:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@page import="java.util.Map" %>
<html>
<head>
<title>jstack monitor</title>
</head>
<body>
<pre>
<%
for(Map.Entry<Thread,StackTraceElement[]> stackTrace : Thread.getAllStackTraces().entrySet()){
Thread thread = (Thread) stackTrace.getKey();
StackTraceElement[] stack = (StackTraceElement[]) stackTrace.getValue();
if(thread.equals(Thread.currentThread())){
continue;
}
out.println("\n 线程:" + thread.getName() + "\n");
for(StackTraceElement element : stack){
out.println("\t" + element + "\n");
}
}
%>
</pre>
</body>
</html>