1.jps:虚拟机进程状况工具(JVM Process Status Tool)
该命令的功能是列出正在运行的Java虚拟机进程,并显示虚拟机执行主类(Main Class,main( )函数所在的类)的名称以及这些进程的本地虚拟机唯一ID(Local Virtual Machine Identifier,LVMID)。对于本地虚拟机来说,LVMID与操作系统的进程ID(Process Identifier,PID)是一致的。
jps命令格式:
jps [option] [hostid]
jps可以通过RMI协议查询开启了RMI服务的远程虚拟机进程状态,hostid为RMI注册表中的主机名。
2.jstat:虚拟机统计信息监视工具(JVM Statistics Monitoring Tool)
该命令是用于监视虚拟机各种运行状态信息的命令行工具。它可以显示本地或者远程虚拟机进程中的类装载、内存、垃圾收集、JIT编译等运行数据,适合纯文本界面,是运行期定位虚拟机性能问题的首选工具。
jstat命令格式:
jstat [option vmid [interval [s|ms] [count]] ]
对于命令格式中的VMID与LVMID需要特别说明一下:如果是本地虚拟机进程,VMID与LVMID是一致的,如果是远程虚拟机进程,那VMID的格式应当是:
[protocol: ] [//] lvmid [@hostname[ :port]/servername]
参数interval和count代表查询间隔和次数,如果省略这两个参数,说明只查询一次。假设需要每250毫秒查询一次进程2764垃圾收集状况,一共查询20次,那命令应当是:
jstat -gc 2764 250 20
选项option代表着用户希望查询的虚拟机信息,主要分为三类:类装载、垃圾收集、运行期编译状况。
3.jinfo:Java配置信息工具(Configuration Info for Java)
该命令的作用是实时地查看和调整虚拟机各项参数。
jinfo命令格式:
jinfo [option] pid
4.jstack:Java堆栈跟踪工具(Stack Trace for Java)
该命令是用于生成虚拟机当前时刻的线程快照(一般称为threaddump或者javacore文件)。线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的主要目的是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等等都是导致线程长时间停顿的常见原因。线程出现停顿的时候通过jstack来查看各个线程的调用堆栈,就可以知道没有响应的线程到底在做什么,或者等待什么资源。
jstack命令格式:
jstack [option] vmid
在jdk1.5中,java.lang.Thread类新增了一个getAllStackTraces( )方法用于获取虚拟机所有线程的StackTraceElement对象。使用这个方法可以通过简单的几行代码就完成jstack的大部分功能,可以做个管理员界面,用浏览器来查看线程堆栈。