一、JDK命令行工具
名称 | 主要作用 |
---|---|
jps | JVM Process Status Tool,显示指定系统内所有的HotSpot虚拟机进程 |
jstat | JVM Statistics Monitoring Tool,用于收集HotSpot虚拟机各方面的运行数据 |
jinfo | Configuration Info for Java,显示虚拟机配置信息 |
jmap | Memory Map for Java,生成虚拟的内存转存储快照 |
jhat | JVM Heap Dump Browser,用于分析heapdump文件,它会建立一个HTTP/HTML服务器,让用户可以在浏览器上查看结果 |
jstack | Stack Trace for Java,显示虚拟机的线程快照 |
1.1、jps:虚拟机进程状况工具
命令格式:
jps [ options ] [ hostid ]
hostid为RMI注册表中的主机名。
options的选项表:
选项 | 作用 |
---|---|
-q | 只输出LVIMD(本地虚拟机唯一ID),省略主类的名称 |
-m | 输出虚拟机进程启动时传递给主类main()函数的参数 |
-l | 输出主类的全名,如果进程执行的是Jar包,输出Jar包的路径 |
-v | 输出虚拟机进程启动时JVM参数 |
1.2、jstat:虚拟机统计信息监视工具
命令格式:
jstat [ option vmid [ interval [ s|ms ] [ count ] ] ]
参数interval和count代表查询间隔和次数,如果省略,则只查询一次。假设需要每25oms查询一次进程2764垃圾收集情况,查询20次:
jstat -gc 2764 250 20
选项option的参数表:
选项 | 作用 |
---|---|
-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编译的方法 |
1.3、jinfo:Java配置信息工具
jinfo的作用时实时查看和调整虚拟机各项参数。
命令格式:
jinfo [ option ] pid
1.4、jmap:Java内存映像工具
用于生存堆转储快照。命令格式:
jmap [ option ] vmid
选项option的可选值:
选项 | 作用 |
---|---|
-dump | 生存Java堆转储快照。 |
-finalizerinfo | 显示在F-Queue中等待Finalizer线程执行finalize方法的对象,只在Linux/Solaris平台下有效 |
-heap | 显示Java堆详细信息,如使用哪种回收器、参数配置、分代情况等,只在Linux/Solaris平台下有效 |
-histo | 显示堆中对象统计信息,包括类、实例数量、合计容量 |
-permstat | 以ClassLoader为统计口径显示永久代内存状态,只在Linux/Solaris平台下有效 |
-F | 当虚拟机进程对-dump选项没有响应时,可使用这个选项强制生成dump快照,只在Linux/Solaris平台下有效 |
1.5、jhat:虚拟机堆转储快照分析工具
与jmap搭配使用,来分析jmap生成的堆转储快照。
1.6、jstack:Java堆栈跟踪工具
用于生成虚拟机当前时刻的线程快照。
二、JDK的可视化工具
上面的命令是JDK通过的命令行分析虚拟机的命令行工具,但是在实际中我们通常使用可视化工具ViualVM来分析虚拟机的状态。
VisualVM是一个多合一故障处理工具,还提供了插件扩展功能,BTrace是它的一个重要插件。