jps:虚拟机进程状况工具
和UNIX的ps命令很像,可以列出来正在运行的虚拟机进程,并显示虚拟机执行主类,名称以及这些进程的本地虚拟机唯一ID,是使用频率最高的JDK命令行工具之一。
选项 | 作用 |
---|---|
-q | 只输出LVMID,省略主类的名称 |
-m | 输出虚拟机进程启动时传递给主类main()函数的参数 |
-l | 启动服务器输出主类的全名,如果进程执行的是JAR包,则输出JAR路径 |
-v | 输出虚拟机进程启动时的JVM参数 |
jstat:虚拟机统计信息监视工具
用于监视虚拟机各种运行状态信息的命令行工具,可以显示本地或者远程虚拟机进程中的类加载、内存、垃圾收集、即时编译等运行数据
jatst [option vmid [interval [s|ms] [count]]]
选项option代表用户要查询的虚拟机信息,主要是三类:类加载、垃圾收集,运行期编译状况。一般为
-class -gc -gccapity -gcutil等
参数interval和count代表查询的间隔和次数,如果省略了这两个参数,表示只查一次,假设需要每250毫秒查询一次进程689垃圾收集情况,一共查询20次,命令如下:
jstat -gc 689 250 20
jinfo:Java配置信息工具
jinfo的作用是事实的查看和调整虚拟机各项参数。jps命令的-v参数可以查看虚拟机启动时显示指定的参数列表,但如果想知道未被显示指定的参数的系统默认值,除了去找资料外,就只能使用jinfo 的 -flag选项进行查询了(如果只限于JDK1.6或以上的版本的话,使用java -XX:+PrintFlagsFinal
查看参数默认值也是一个很不错的选择),jinfo还可以使用-sysprops选项吧虚拟机进程的System.getProperties()的内容打印出来。
jinfo命令格式:
jinfo [option] pid
jmap:java内存映像工具
jmap命令用于生成堆转储快照(一般称为heapdump或dump文件)。如果不使用jmap命令,要想获取Java堆转储快照,还有一些比较“暴力”的手段:譬如在第2章中用过的-XX:+HeapDumpOnOutOfMemoryError
参数,可以让虚拟机在OOM异常出现之后自动生成dump文件,通过-XX:+HeapDumpOnCtrlBreak
参数则可以使用[Ctrl]+[Break]键让虚拟机生成dump文件。
jmap的作用并不仅仅是为了获取dump文件,它还可以查询finalize执行队列、Java堆和永久代的详细信息,如空间使用率、当前用的是哪种收集器等。
和jinfo命令一样,jmap有不少功能在Windows平台下都是受限的,除了生成dump文件的-dump选项和用于查看每个类的实例、空间占用统计的-histo选项在所有操作系统都提供之外,其余选项都只能在Linux/Solaris下使用。
jmap命令格式:
jmap [option] vmid
jhat:虚拟机堆转储快照分析工具
jhat (jvm heap analysis tool) 命令与jmap搭配使用来分析jmap生成的堆转储快照。
在浏览器输入
http://localhost:7000/
jstack:Java堆栈跟踪工具
jstack用于生成java虚拟机当前时刻的线程快照。线程快照是当前java虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的主要目的是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等。 线程出现停顿的时候通过jstack来查看各个线程的调用堆栈,就可以知道没有响应的线程到底在后台做什么事情,或者等待什么资源。