JVM系列(六)JVM优化常用工具

在jdk的bin目录下有跟多的 *.exe命令行工具,这些工具非常强大可以监控虚拟机和故障处理。


名称 作用描述
jps JVM进程状态工具(JVM Process Status Tool)用于显示目标系统上JVM的java进程
jstat JVM统计监测工具(JVM Statistics Monitoring Tool)主要用于监测显示JVM的性能统计信息
jinfo java配置信息工具(JAVA Configuration Information)用于打印指定java进程核心文件或者远程调用服务的配置信息
jhat java堆分析工具(JAVA Heap Analysis Tool)用于分析java堆内存中的对象信息
jmap java内存映射工具(JAVA Memory Map)主要用于打印java进程,核心文件或者远程调用服务器的共享对象内存映射或者堆内存细节
jstack java堆栈跟踪工具,主要用于打印指定java进程,核心文件或者远程调用服务器的java线程的堆栈跟踪信息
jmc java任务控制工具(JAVAMission Control) 主要用于JVM的生产时间监测,分析诊断
jvisualvm jvm 监测,故障排除,分析工具,主要以图形化界面的方式提供运行与指定虚拟机的java应用程序的详细信息
jconsole 图形化用户界面监测工具,主要用于监测并显示运行与java平台上的应用程序的性能和资源占用等信息

1.1 jps 虚拟机进程状况工具

功能:显示正在运行的虚拟机进程

参数:-mlvV

1.2 jinfo

功能:显示jvm运行的参数

参数:

1.3 jstat 运行状态信息

功能:显示本地或远程虚拟机进程中的类装载,内存,垃圾收集,JIT编译等运行数据,是定位虚拟机性能问题的首选工具;定位死锁

用法: jstat [-命令选项] [vmid] [间隔时间-毫秒] [查询次数]

命令选项 描述
-class 监视类装载、卸载数量、总空间以及耗费的时间
-compiler 输出JIT编译过的方法数量耗时等
-gc 垃圾回收堆的行为统计,常用命令
-gccapacity 同-gc,还会输出Java堆各区域使用到的最大、最小空间
-gcutil 同-gc,输出的是已使用空间占总空间的百分比
-gccause 垃圾收集统计概述(同-gcutil),附加最近两次垃圾回收事件的原因
-gcnew 统计新生代行为
-gcnewcapacity 新生代与其相应的内存空间的统计
-gcold 统计老年代行为
-gcoldcapacity 老年代与其相应的内存空间的统计
-gcpermcapacity 永久代与其相应内存空间的统计
-printcompilation hotspot编译方法统计

1.4 jmap 内存dump信息

分析堆

功能:用于生成heap dump 文件,如果不使用这个命令 还可以使用 -XX:HeapDumpOnOutMemoryError参数来让虚拟机出现OOM的时候自动生成dump文件,jmap不仅能生成dump文件,还可以查询finalize执行队列,java堆,和永久代的详细信息,如当前使用率,当前使用的那种收集器

用法: jmap [-命令选项] [vmid]

Memory Analyzer Tool = MAT (分析hprof)http://www.eclipse.org/mat/downloads.php

Attach Listener:负责接收外部命令
Single Dispactcher:接收命令收分发给不同的模块
Finalizer:执行用户finalizer方法的线程
Reference Handler:处理对象引用(软引用/弱引用/虚引用)

1.5 jstack 堆栈跟踪工具

功能:用于生成虚拟机当前时刻的线程快照,以便可以进一步定位线程出现长时间停顿的原因。如线程死锁,死循环,请求外部资源长时间等待等

用法: jstack [-命令选项] [vmid]

cpu满了,死循环堆cpu消耗很高

1.6 jvisualvm jconsole工具

升级版

由于 jconsole jvisualvm 相对来说很繁琐,甚至官方操作手册都长达几十页;后续想好会补充

jvisualvm插件地址:https://visualvm.github.io/index.html

根据自己的JDK版本下载相应版本的插件


原文链接

发布了12 篇原创文章 · 获赞 0 · 访问量 344

猜你喜欢

转载自blog.csdn.net/fd135/article/details/104286840
今日推荐