虚拟机进程状况工具,可以列出正在运行的虚拟机进程,并显示虚拟机执行主类(MainClass,main()函数所在的类)名称以及这些进程的本地虚拟机唯一ID(Local Virtual Machine Identifier,LVMID)。
jps[options][hostid]
-q -m -l -v
虚拟机统计信息监视工具,用于监视虚拟机各种运行状态信息的命令行工具。它可以显示本地或者远程虚拟机进程中的类装载、内存、垃圾收集、JIT编译等运行数据,在没有GUI图形界面,只提供了纯文本控制台环境的服务器上,它将是运行期定位虚拟机性能问题的首选工具。
jstat[option vmid[interval[s|ms][count]]] [protocol:][//]lvmid[@hostname[:port]/servername]
// 每250毫秒查询一次进程2764垃圾收集状况,一共查询20次 jstat-gc 2764 250 20
-class
:监视类装载、卸载数量、总空间和类装载消耗的时间 -gc
:监视java堆状况,包括Eden区、2个Survivor区、老年代、永久代等的容量,已用空间,GC时间合计等信息 -gccapacity
: 监视内容与 -gc
相同,但输出主要关注Java堆各个区域使用到的最大、最小空间 -gcutil
:监视内容与 -gc
相同,但输出主要关注已使用空间占总空间的百分百 -gccause
:与 -gcutil
一样,但会额外输出上一次GC产生的原因 -gcnew
:监视新生代GC的状况 -gcnewcapacity
:监视内容与 -gcnew
相同,输出主要关注使用到的最大、最小空间 -gcold
:监视老年代GC的状况 -gcoldcapacity
:监视内容与 -gcold
相同,输出主要关注使用到的最大、最小空间 -gcpermcapacity
:输出永久代使用到的最大、最小空间 -compiler
:输出JIT编译过的方法、耗时等信息 -printcompilation
:输出已被JIT编译的方法 Java配置信息工具,可实时查看和调整虚拟机各项参数。
jinfo[option]pid
-flag -flags -sysprops
Java内存映像工具用于生成堆转储快照(dump文件)
Kill-3
jmap[option]vmid
-dump -finalizerinfo -heap -histo -permstat -F
与jmap搭配使用,用来分析jmap生成的堆转储快照。jhat内置了一个微型的HTTP/HTML服务器,生成dump文件的分析结果后,可以在浏览器中查看。
jhat [dumpfile]
Java堆栈跟踪工具,用于生成虚拟机当前时刻的线程快照。
线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的主要目的是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等都是导致线程长时间停顿的常见原因。
线程出现停顿的时候通过jstack来查看各个线程的调用堆栈,就可以知道没有响应的线程到底在后台做些什么事情,或者等待着什么资源。
jstack[option]vmid
-F -l -m
java.lang.Thread
类新增了一个 getAllStackTraces()
方法用于获取虚拟机中所有线程的StackTraceElement对象。