1.Sun JDK监控与故障处理工具
①在JAVA_HOME/bin目录下
名称 | 作用 |
---|---|
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,显示虚拟机的线程快照 |
2.jps:虚拟机进程状况工具
①命令格式:jps [options] [hostid]
选项 | 作用 |
---|---|
-q | 只输出LVMID,省略主类的名称 |
-m | 输出虚拟机进程启动时传递给主类main()函数的参数 |
-l | 输出主类的全名,如果进程执行的是Jar包,输出Jar路径 |
-v | 输出虚拟机进程启动时JVM参数 |
3.jstat:虚拟机统计信息监视工具
①用于监视虚拟机各种运行状态信息的命令行工具。可以显示本地或远程虚拟机中的类装载、内存、垃圾收集、JIT编译等运行数据
②命令格式:jstat [option vmid [intervsl [s|ms] [count]]]
③示例:jstat -gc 2764 250 20
每250毫秒查询一次进程2764垃圾收集状况,一共查询20次
选项 | 作用 |
---|---|
-class | 监视类装载、卸载数量、总空间及类装载所耗费的时间 |
-gc | 监视Java堆状况,包括Eden区,两个Survivor区、老年代、永久代等的容量、已用空间、GC时间合计等信息 |
-gccapacity | 监视内容与gc基本相同,但输出主要关注Java堆各个区域使用到最大最小空间 |
-gcutil | 监视内容与gc基本相同,但输出主要关注已使用空间占总空间的百分比 |
-gccause | 与-gcutil功能一样,但是会额外输出导致上一次GC产生的原因 |
-gcnew | 监视新生代GC状况 |
-gcnewcapacity | 监视内容与-gcnew基本相同,输出主要关注使用到最大、最小空间 |
-gcold | 监视老年代GC状况 |
-gcoldcapacity | 监视内容与-gcold基本相同,输出主要关注使用到的最大、最小空间 |
-gcpermcapacity | 输出永久代使用到的最大、最小空间 |
-compiler | 输出JIT编译器编译过的方法、耗时等信息 |
-printcompilation | 输出已经被JIT编译的方法 |
4.jinfo:java配置信息工具
①作用是实时查看和调整虚拟机各项参数
5.jmap:java内存映像工具
①用于生成堆转储快照(一般称为heapdump或Dump文件)
②-XX:HeapDumpOnOutOfMemoryError参数,可以让虚拟机在OOM异常出现后自动生成dump文件
③在linux 通过kill -3 命令发送进程退出信号“吓唬”一下虚拟机,也能拿到Dump文件
④命令格式:jmap [option] vmid
实例:jmap -dump:format=b,file=eclipse.bin 3500
选项 | 作用 |
---|---|
-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平台下有效 |
6.jhat:虚拟机堆转储快照分析工具
7.jstack:java堆栈跟踪工具
①用于生成虚拟机当前时刻的线程快照(一般称为threaddump或Javacore文件)
②线程快照就是当前虚拟机类每一条线程正在执行的方法堆栈的集合,生成快照的主要目的是定位线程长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等
③命令格式:jstack [option] vmid
选项 | 作用 |
---|---|
-F | 当正常输出的请求不被响应时,强制输出线程的堆栈 |
-l | 除堆栈外,显示关于锁的附加信息 |
-m | 如果调用本地方法,可以显示C/C++的堆栈 |
8.JConsole与VisualVM可视化工具