一、基于命令行
1. jps
功能
类似与 UNIX 的 ps 命令,可列出正在运行的虚拟机进程,并显示虚拟机执行主类名称及这些进程的本地虚拟机唯一 ID(LVMID)。
格式
jps [ options ] [ hostid ]
示例
图1. jps 命令示例
选项
选项 | 作用 |
---|---|
-q | 主输出 LVMID,省略主类的名称 |
-m | 输出虚拟机进程启动时传递给主类 main() 函数的参数 |
-l | 输出主类的全名,如果进程执行的是 JAR 包,则输出 JAR 路径 |
-v | 输出虚拟机进程启动时的 JVM 参数 |
2. jstat
功能
用于监视虚拟机各种运行状态信息的工具。既可以显示本地或者远程虚拟机进程中的类加载、内存、垃圾收集、即时编译等运行时数据。也许不如图形化那么直观,但在没有 GUI 图形界面,只提供纯文本控制台环境的生产环境服务器上,它是运行期定位性能问题的常用工具。
格式
jstat [ option vmid [ interval[s|ms] [count] ] ]
其中,interval 和 count 代表查询间隔和次数,如果省略俩参数,则只查询一次。
示例
图2. jstat 命令示例
如图,第一个命令即省略参数,只进行一次查询;而设置interval 为 250ms,count 为 20时,会进行每 250ms 查询一次进程 22288 垃圾收集状况,一共查询 20 次(图未截取完整)。
选项
选项 | 作用 |
---|---|
-class | 监视类加载、卸载数量、总空间以及类装载所耗费的时间 |
-gc | 监视 Java 堆状况,包括 Eden 区、两个 Survivor 区、老年代、永久代等的容量,已用空间,垃圾收集时间合计等信息 |
-gccapcity | 监视内容与 -gc 基本相同,但关注 Java 堆各个区域使用到的最大、最小空间 |
-gcutil | 监视内容与 -gc 基本相同,但关注已使用空间占总空间百分比 |
-gccause | 与 -gcutil 功能一样,但是会额外输出导致上一次垃圾收集产生的原因 |
-gcnew | 监视新生代垃圾收集状况 |
-gcold | 监视老年代垃圾收集状况 |
-gcpermcapcity | 输出永久代使用到的最大、最小空间 |
二、可视化
JDK 附带了几个功能集成度更高的可视化工具,包括:JConsole、JHSDB、VisualVM 和 JMC 四个。
1.JSHDB
功能
JHSDB 可提供命令行模式和可视化模式,它是一款基于服务性代理实现的进程外调试工具
2. JConsole
功能
- 内存监控,相对于 jstat
- 线程监控,相当于 jstack,可检测死锁。
3. VisualVM
功能
最强大的运行监视器和故障处理程序之一。基本 NetBeans 平台开发工具,具备插件扩展功能。