JVM系列八(虚拟机性能监控命令).
jps
JVM Process Status Tool,显示指定系统内所有的 HotSpot 虚拟机进程。显示信息包括虚拟机执行主类名称以及这些进程的本地虚拟机唯一ID(Local Virtual Machine Identifier,LVMID)。
jps [-q] [-mlvV] [<hostid>]
| 选项 | 作用 |
|---|---|
| -q | 只输出 LVMID,省略主类的名称 |
| -m | 输出虚拟机进程启动时传递给主类 main() 函数的参数 |
| -l | 输出主类的名称,如果进程执行的是 jar 包,输出 jar 路径 |
| -v | 输出虚拟机进程启动时 JVM 参数 |
jstat
JVM Statistics Monitoring Tool,用于收集 HotSpot 虚拟机各方面的运行数据。包括显示本地或者远程虚拟机进程中的类装载、内存、垃圾收集、JIT 编码等运行数据。
jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]
参数 interval 和 count 代表查询间隔和次数,如果省略这两个参数,说明只查询一次。
| 选项 | 作用 |
|---|---|
| -class | 监视类装载、卸载数量、总空间以及类装载所耗费的时间 |
| -compiler | 输出 JIT 编译过的方法、耗时等信息 |
| -printcompilation | 输出已经被 JIT 编译的方法 |
| -gc | 监视 Java 堆状况 |
| -gccapacity | 监视 Java 堆状况,关注堆各个区域使用到的最大、最小空间 |
| -gcutil | 监视 Java 堆状况,关注已使用空间占总空间的比例 |
| -gccause | 与 gcutil 功能一样,额外输出导致上一次 GC 产生的原因 |
| -gcnew | 监视新生代 GC 状况 |
| -gcnewcapacity | 监视堆新生代 GC 状况,关注使用到的最大、最小空间 |
| -gcold | 监视老年代 GC 状况 |
| -gcoldcapacity | 监视老年代 GC 状况,关注使用到的最大、最小空间 |
| -gcmetacapacity | 输出元空间使用到的最大、最小空间 |

tips: 监控指标的含义,不是本文的重点,可在具体使用到的时候再去查询。
jinfo
Configuration Info for Java,实时的查看和调整虚拟机的各项参数。
jinfo [option] <pid>
| 选项 | 作用 |
|---|---|
| -flag <name> | 查看虚拟机进程某个配置项的值 |
| -flag [+/-]<name> | 开启/关闭虚拟机进程某个配置项 |
| -flag <name>=<value> | 动态设置虚拟机进程某个配置项 |
| -flags | 打印虚拟机进程非默认的配置项以及用户启动时设置的虚拟机参数 |
| -sysprops | 打印虚拟机进程的 System.getProperties() 的内容 |

jmap
Memory Map for Java,生成虚拟机的内存存储快照(heapdump 文件或 dump 文件),查询 finalize 执行队列、Java 堆等信息。
jmap [option] <pid>
| 选项 | 作用 |
|---|---|
| -dump:<dump-options> | 生成 Java 堆存储快照。格式为:-dump[:live,]format=b,file=<filename> <pid> 。其中 live 参数说明只 dump 出存活的对象 |
| -finalizerinfo | 显示在 F-Queue 中等待 Finalize 线程执行 finalize 方法的对象 |
| -heap | 显示 Java 堆详细信息 |
| -histo | 显示堆中对象统计信息,包括类、实例变量、合计容量 |
| -F | 当虚拟机进程对 -dump 选项没有响应时,可使用这个选项强制生成 dump 快照 |

那么问题来了,有了 dump 文件后,我们该怎么对 dump 文件进行解读呢?这里推荐个人一直在使用的网站:https://console.perfma.com/,只要将生成的 dump 文件上传到网站上,就能得到分析结果。(目测原理是 jhat 命令 —— 虚拟机堆转储快照分析工具)

tips: 除了使用 jmap 命令,还可以使用 -XX:+HeapDumpOnOutOfMemoryError 参数,让虚拟机在 OOM 异常出现之后自动生成 dump 文件。
jstack
Stack Trace for Java,用于生成虚拟机当前时刻的线程快照(一般称为 threaddump 或者 javadoc 文件)。线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的主要目的是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等都是导致线程长时间停顿的常见原因。
jstack [option] <pid>
| 选项 | 作用 |
|---|---|
| -F | 当正常输出的请求不被响应时,强制输出线程堆栈 |
| -m | 如果调用本地方法(native)的话,可以显示 C/C++ 堆栈信息 |
| -l | 除堆栈外,显示关于锁的附加信息 |

堆栈的分析也可以上传到 https://console.perfma.com/ 查看分析结果,需要注意的是 dump 文件中的线程号是以 16 进制表示的,所以我们定位线程的时候,也要把线程号转化为 16 进制。
tips: 给一个系统定位问题的时候,知识、经验是关键基础,数据是依据,工具是运用知识处理数据的手段。
JVM系列八(虚拟机性能监控命令).的更多相关文章
- 深入理解JVM(③)虚拟机性能监控、故障处理工具
前言 JDK的bin目录中有一系列的小工具,除了java.exe.javac.exe这两个编译和运行Java程序外,还有打包.部署.签名.调试.监控.运维等各种场景都会用到这些小工具. 这些工具根据软 ...
- 【JVM.3】虚拟机性能监控与故障处理工具
一.概述 经过前面两章对于虚拟机内存分配与回收技术各方面的介绍,相信读者已经建立了一套比较完整的理论基础.理论总是作为指导实践的工具,能把这些执行应用到实际工作中才是我们的最终目的.接下来我们会从实践 ...
- JVM基础系列第15讲:JDK性能监控命令
查看虚拟机进程:jps 命令 jps 命令可以列出所有的 Java 进程.如果 jps 不加任何参数,可以列出 Java 程序的进程 ID 以及 Main 函数短名称,如下所示. $ jps 6540 ...
- JDK性能监控命令
阅读原文 查看虚拟机进程:jps 命令 jps 命令可以列出所有的 Java 进程.如果 jps 不加任何参数,可以列出 Java 程序的进程 ID 以及 Main 函数短名称,如下所示. $ jps ...
- JYM虚拟机性能监控与故障处理工具
虚拟机性能监控与故障处理工具 一.jps:虚拟机进程状况工具 常用指令 二.jstat:虚拟机统计信息监视工具 常用指令 三.jinfo:配置信息工具 四.jmap:Java内存映像工具 常用指令 五 ...
- 《深入理解Java虚拟机》(四)虚拟机性能监控与故障处理工具
虚拟机性能监控与故障处理工具 详解 4.1 概述 本文参考的是周志明的 <深入理解Java虚拟机> 第四章 ,为了整理思路,简单记录一下,方便后期查阅. JDK本身提供了很多方便的JVM性 ...
- Java虚拟机性能监控与调优实战
From: https://c.m.163.com/news/a/D7B0C6Q40511PFUO.html?spss=newsapp&fromhistory=1 Java虚拟机性能监控与调 ...
- jvm虚拟机性能监控与故障处理工具
java开发人员肯定知道jdk的bin目录中有java.exe javac.exe这两个命令行工具,但并非所有程序员都了解过jdk的bin目录之中其他命令行的作用.jdk的工具,体积都比较小,这些命令 ...
- Linux下的java虚拟机性能监控与故障处理命令
java包中提供了很多监控JVM的工具类,作为java程序员必须得掌握常用的几个工具,下面是几个常用的JVM性能监控与故障处理工具的介绍与使用. 1.jstack 该命令用于生成当前时刻虚拟机的线程快 ...
随机推荐
- 测试误区《二》 python逻辑运算和关系运算优先级
关系运算 关系运算就是对2个对象进行比较,通过比较符判断进行比较,有6种方式. x > y 大于 x >= y 大于等于 x < y 小于 x <= y 小于等于 x = y ...
- keepalive笔记之二:keepalive+nginx(自定义脚本实现,上述例子也可以实现)
keepalive的配置文件 ! Configuration File for keepalived global_defs { notification_email { acassen@firewa ...
- AVFoundation Programming Guide(官方文档翻译4)Editing - 编辑
新博客:完整版 - AVFoundation Programming Guide 分章节版:- 第1章:About AVFoundation - AVFoundation概述- 第2章:Using A ...
- flutter实践 - plsy
项目背景 项目需要从钉钉微应用跳转 WPS 打开 word 文档,但是 WPS 只提供了 StartActivity 方式携带参数跳转应用,deeplink 只能打开应用,而钉钉微应用只支持 deep ...
- 在python中连接mysql数据库,并进行增删改查
数据库在开发过程中是最常见的,基本上在服务端的编程过程中都会使用到,mysql是较常见的一种数据库,这里介绍python如果连接到数据库中,并对数据库进行增删改查. 安装mysql的python扩展 ...
- ant:如何用ant将web project打包成war包
说明:src中的文件将不会呈现出来,诸位可以自己写一个简单的web项目,然后依照我所提供的ant脚本配置来设置. 文件结构如图所示: 配置为下: build.xml < ...
- 海洋深处的数据中心——微软Natick项目
数据中心(data center)是云计算的支柱,云计算的蓬勃发展离不开数据中心在建造运营方面的不断创新.但云端数据中心的运行过程中会产生大量热量,冷却降温过程则意味着巨大的能源消耗,这意味着需要庞大 ...
- “一亿”的教训:一次Google信箱诈骗是如何得手的?
网络诈骗是指以非法占有为目的,利用互联网采用虚构事实或者隐瞒真相的方法,骗取数额较大的公私财物的行为.一年比一年网络诈骗越来越高手段,可以说是日益猖獗.在这里提醒一次各位朋友一定要注意自己的网络安全. ...
- 基于 HTML5 Canvas 的 3D 热力云图效果
前言 数据蕴藏价值,但数据的价值需要用 IT 技术去发现.探索,可视化可以帮助人更好的去分析数据,信息的质量很大程度上依赖于其呈现方式.在数据分析上,热力图无疑是一种很好的方式.在很多行业中都有着广泛 ...
- Ado.net 02
1.连接字符串不同,连接池也不同 SqlConnection对象只能被打开一次.但是在Close()后再进行Open()操作.但是在Dispose()之后就不能再Open()了. 2.SqlDataA ...