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系列八(虚拟机性能监控命令).的更多相关文章

  1. 深入理解JVM(③)虚拟机性能监控、故障处理工具

    前言 JDK的bin目录中有一系列的小工具,除了java.exe.javac.exe这两个编译和运行Java程序外,还有打包.部署.签名.调试.监控.运维等各种场景都会用到这些小工具. 这些工具根据软 ...

  2. 【JVM.3】虚拟机性能监控与故障处理工具

    一.概述 经过前面两章对于虚拟机内存分配与回收技术各方面的介绍,相信读者已经建立了一套比较完整的理论基础.理论总是作为指导实践的工具,能把这些执行应用到实际工作中才是我们的最终目的.接下来我们会从实践 ...

  3. JVM基础系列第15讲:JDK性能监控命令

    查看虚拟机进程:jps 命令 jps 命令可以列出所有的 Java 进程.如果 jps 不加任何参数,可以列出 Java 程序的进程 ID 以及 Main 函数短名称,如下所示. $ jps 6540 ...

  4. JDK性能监控命令

    阅读原文 查看虚拟机进程:jps 命令 jps 命令可以列出所有的 Java 进程.如果 jps 不加任何参数,可以列出 Java 程序的进程 ID 以及 Main 函数短名称,如下所示. $ jps ...

  5. JYM虚拟机性能监控与故障处理工具

    虚拟机性能监控与故障处理工具 一.jps:虚拟机进程状况工具 常用指令 二.jstat:虚拟机统计信息监视工具 常用指令 三.jinfo:配置信息工具 四.jmap:Java内存映像工具 常用指令 五 ...

  6. 《深入理解Java虚拟机》(四)虚拟机性能监控与故障处理工具

    虚拟机性能监控与故障处理工具 详解 4.1 概述 本文参考的是周志明的 <深入理解Java虚拟机> 第四章 ,为了整理思路,简单记录一下,方便后期查阅. JDK本身提供了很多方便的JVM性 ...

  7. Java虚拟机性能监控与调优实战

    From:  https://c.m.163.com/news/a/D7B0C6Q40511PFUO.html?spss=newsapp&fromhistory=1 Java虚拟机性能监控与调 ...

  8. jvm虚拟机性能监控与故障处理工具

    java开发人员肯定知道jdk的bin目录中有java.exe javac.exe这两个命令行工具,但并非所有程序员都了解过jdk的bin目录之中其他命令行的作用.jdk的工具,体积都比较小,这些命令 ...

  9. Linux下的java虚拟机性能监控与故障处理命令

    java包中提供了很多监控JVM的工具类,作为java程序员必须得掌握常用的几个工具,下面是几个常用的JVM性能监控与故障处理工具的介绍与使用. 1.jstack 该命令用于生成当前时刻虚拟机的线程快 ...

随机推荐

  1. springboot学习笔记:11.springboot+shiro+mysql+mybatis(通用mapper)+freemarker+ztree+layui实现通用的java后台管理系统(权限管理+用户管理+菜单管理)

    一.前言 经过前10篇文章,我们已经可以快速搭建一个springboot的web项目: 今天,我们在上一节基础上继续集成shiro框架,实现一个可以通用的后台管理系统:包括用户管理,角色管理,菜单管理 ...

  2. C++对数组进行复制

    C++ 风格的复制操作 使用STL中的copy算法 int a[] = {1,2,3,4,5}; int b[5]; std::copy(std::begin(a),std::end(a),std:: ...

  3. 使用jQuery的".css()"和".attr()"方法设置元素"left"属性的注意点

    今天在使用jQuery方法".css()"设置"ajax-loader.gif"的位置时出了点小状况,关键代码如下(为了简化,这里假定要给"ajax- ...

  4. CDC与HDC的区别以及相互转换

    CDC是MFC的DC的一个类  HDC是DC的句柄,API中的一个类似指针的数据类型.  MFC类的前缀都是C开头的  H开头的大多数是句柄  这是为了助记,是编程读\写代码的好的习惯.  CDC中所 ...

  5. js事件节流

    背景:在监听浏览器滚动条的scroll事件时该事件会触发很多次,这样当快速滚动时会有很差的性能,所以要限制事件触发的频率,可以防抖和节流,这里我记录简单的节流方法 <!DOCTYPE html& ...

  6. Openstack neutron学习

    最近在学习openstack neutron的东西,记录下自己的一些理解. 网络基础知识 Switches & Vlan交换机的作用是来连接设备,实现互通的.network host之间通过交 ...

  7. 神州优车挂牌新三板!专车B2C对决C2C将愈发狂暴?

    近日,全国中小企业股份转让系统公告显示,神州优车已获准在新三板挂牌.神州优车作为神州专车的主营主体,此次挂牌新三板意味着神舟专车成功突围,成为"专车第一股".相比滴滴.Uber中国 ...

  8. 安卓权威编程指南 -笔记(19章 使用SoundPool播放音频)

    针对BeatBox应用,可以使用SoundPool这个特别定制的实用工具. SoundPool能加载一批声音资源到内存中,并支持同时播放多个音频文件.因此所以,就算用户兴奋起来,狂按按钮播放全部音频, ...

  9. Hibernate入门之主键生成策略详解

    前言 上一节我们讲解了Hibernate命名策略,从本节我们开始陆续讲解属性.关系等映射,本节我们来讲讲主键的生成策略. 主键生成策略 JPA规范支持4种不同的主键生成策略(AUTO.IDENTITY ...

  10. CSS中怎么设置元素水平垂直居中?

    记录怎么使用text-align与vertical-align属性设置元素在容器中垂直居中对齐.text-align与vertical-align虽然都是设置元素内部对齐方式的,但两者的用法还是有略微 ...