主要学习并记录在命令行中操作服务器时使用的六大命令工具,可视化工具JConsole和VisualVM在开发过程中熟悉。
一、jps:虚拟机进程状况工具(JVM Process Status Tool)
    列出正在运行的虚拟机进程,并显示虚拟机执行主类的名称和这些进程的本地虚拟机唯一ID(LVMID)。
    快速定位到某个虚拟机进程。
    jps命令格式:
        jps [options] [hostid]
    Options:
        -q    只输出LVMID,省略主类的名称;
        -m    输出虚拟机进程启动时传递给主类Main()函数的参数;
        -l    输出主类的全名,如果进程执行的是jar包,输出jar路径;
        -v    输出虚拟机进程启动时JVM参数;
    HostId:
        通过RMI协议查询开启了RMI服务的远程虚拟机进程状态。
        jps 192.168.8.7 //查看远程计算机192.168.8.7的情况(默认1099端口)
        jps rmi://192.168.8.7:8888 //查看远程计算机192.168.8.7 8888端口 
 
二、jstat:虚拟机统计信息监视工具(JVM Statistics Monitoring Tool)
    监视虚拟机各种运行状态信息,显示本地或远程虚拟机进程中的类装载、内存、垃圾收集、JIT编译等运行数据。
    jstat命令格式:
        jstat [option vmid [ interval [s|ms] [count] ] ]
    Options:
        -class    监视类装载、卸载数量、总空间及类装载所耗费的时间;
        -gc    监视Java堆状态,包括Eden区(E)、2个Survivor区(S0,S1)、老年代(O)、永久代(P)等的容量、已用空间、GC时间合计等信息;
        -gccapacity    监视内容与-gc基本相同,但输出主要关注Java堆各个区域使用到的最大和最小空间;
        -gcutil     监视内容与-gc基本相同,但输出主要关注已使用空间占总空间的百分比;
        -gccause    与-gcutil功能一样,但是会额外输出导致上一次gc产生的原因;
        -gcnew    监视新生代gc的状况;
        -gcnewcapacity    监视内容与-gcnew基本相同,输出主要关注使用到的最大和最小空间;
        -gcold    监视老年代gc的状况;
        -gcoldcapacity    监视内容与-gcold基本相同,输出主要关注使用到的最大和最小空间;
        -gcpermcapacity    输出永久代使用到的最大和最小空间;
        -compiler    输出JIT编译器编译过的方法、耗时等信息;
        -printcompilation    输出已经被JIT编译的方法;
 
三、jinfo:Java配置信息工具(Configuration Info for Java)
    实时查看和调整虚拟机的各项参数。
    使用-flag [+/-]name或 -flag name=value修改一部分运行时可写的虚拟机参数。
    jinfo命令格式:
        jinfo [option] pid
    Options:
        -flag name    输出指定name的JVM参数;
        -flag [+|-]name    启用或禁用指定name的JVM参数;
        -flag name=value    设置指定name的JVM参数;
        -flags    打印传递给JVM命令行标志;
        -sysprops    打印Java系统属性键值对;
四、jmap:Java内存映像工具(Memory Map for Java)
    可用于生成堆转储快照,查询finalize执行队列,Java堆和永久代的详细信息等。
    jmap命令格式:
        jmap [option] vmid
    Options:
        -dump    生成Java堆转储快照;
        -finalizerinfo    显示在F-Queue中等待Finalizer线程执行finalize方法的对象;
        -heap    显示Java堆详细信息,如使用哪种回收器、参数配置、分代状况等;
        -histo    显示堆中对象统计信息,包括类、实例数量和合计容量;
        -permstat    以ClassLoader为统计口径显示永久代内存状态;
        -F    当虚拟机进程对-dump选项没有响应时,可以使用这个选项强制生成dump快照;
五、jhat:虚拟机堆转储快照分析工具(JVM Heap Analysis Tool)
    与jmap命令搭配使用,来分析堆转储快照。
    如非必要,不要生产环境分析堆转储快照,建议将dump文件拷贝出来使用Eclipse Memory Analysis(mat)工具分析。
    jhat命令格式:
        jhat [ options ] <heap-dump-file>
六、jstack:Java堆栈跟踪工具(Stack Trace for Java)
    用于生成虚拟机当前时刻的线程快照,定位线程出现长时间停顿的原因。
    jstack命令格式:
        jstack [option] vmid
    Options:
        -F    当正常输出的请求不被响应时,强制输出线程堆栈;
        -l    除堆栈外,显示关于锁的附加信息;
        -m    如果调用到本地方法的话,可以显示C/C++的堆栈;
小结:这六大命令在排查线上问题时很有用,不用死记硬背,平时用的时候,用man命令可获取命令说明,如果能记住并熟练的使用,可以提高排查问题的效率,故在这里手动的敲一遍,加深印象。

《深入理解Java虚拟机》笔记--第四章、虚拟机性能监控与故障处理工具的更多相关文章

  1. 第七章 JVM性能监控与故障处理工具(1)

    1.定位系统问题 依据 GC日志 堆转储快照(heapdump/hprof文件) 线程快照(threaddump/javacore文件) 运行日志 异常堆栈 分析依据的工具 jps:显示指定系统内的所 ...

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

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

  3. java虚拟机之性能监控与故障处理工具

    sun jdk性能监控与故障处理工具 jps: 可以列出正在运行的虚拟机进程,并显示虚拟机执行主类名称以及这些进程的本地虚拟机唯一id. jstat: 用于监视虚拟机各种运行状态信息的命令航工具.它可 ...

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

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

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

    上节学习回顾 从课本章节划分,<垃圾收集器>和<内存分配策略>这两篇随笔同属一章节,主要是从理论+实验的手段来讲解JVM的内存处理机制.好让我们对JVM运行机制有一个良好的概念 ...

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

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

  7. JVM(4) 虚拟机性能监控与故障处理工具

    1. Sun JDK 监控和故障处理工具 1)jps:JVM process Status Tool,显示指定系统内所有的HotSpot虚拟机进程.可以列出正在运行的虚拟机进程,并显示虚拟机执行主类( ...

  8. 深入理解Java虚拟机之读书笔记四 性能监控与故障处理工具

    JDK的bin目录下存在很多有效的命令行工具,它们就是jdk\lib\toos.jar类库的封装. 一.jps:虚拟机进程状况工具,查询出LVMID. 二.jstat:虚拟机统计信息监视工具, 三.j ...

  9. 《深入理解Java虚拟机》-----第4章 虚拟机性能监控与故障处理工具

    理论总是作为指导实践的工具,能把这些知识应用到实际工作中才是 我们的最终目的. 给一个系统定位问题的时候,知识.经验是关键基础,数据是依据,工具是运用知识处理数据的手段.这里说的数据包括:运行日志.异 ...

随机推荐

  1. Python网络编程socket

    网络编程之socket 看到本篇文章的题目是不是很疑惑,what is this?,不要着急,但是记住一说网络编程,你就想socket,socket是实现网络编程的工具,那么什么是socket,什么是 ...

  2. 【Java】list转换json的中文乱码问题

    添加如图红框内容

  3. 51nod 1277字符串中的最大值(拓展kmp)

    题意: 一个字符串的前缀是指包含该字符第一个字母的连续子串,例如:abcd的所有前缀为a, ab, abc, abcd. 给出一个字符串S,求其所有前缀中,字符长度与出现次数的乘积的最大值.   题解 ...

  4. DelayQueue实现Java延时任务

    最近公司需要实现一个订单超时自动关闭的功能,由Java这块来实现 一开始我以为就是定时任务,深入了解了之后发现并不是,官方名称应该叫延时任务,到时间之后 执行传过来的回调函数 这个功能我一共前前后后写 ...

  5. 洛谷 P2258 子矩阵

    题目描述 给出如下定义: 子矩阵:从一个矩阵当中选取某些行和某些列交叉位置所组成的新矩阵(保持行与列的相对顺序)被称为原矩阵的一个子矩阵. 例如,下面左图中选取第2.4行和第2.4.5列交叉位置的元素 ...

  6. linux内核分析 第一周 计算机是如何工作的 20125221银雪纯

    我使用的c语言代码是: int g(int x) { return x + 1; } int f(int x) { return g(x); } int main(void) { return f(6 ...

  7. mac Source Tree免登陆方法

    打开SourceTree -> 点击菜单栏的 窗口 选项 -> 点击显示托管在远端的仓库 -> 点击登录注册页面右上角的关闭按钮 -> 点击Quit -> 点击确定关闭刷 ...

  8. 框架----Django内置Admin

    Django内置的Admin是对于model中对应的数据表进行增删改查提供的组件,使用方式有: 依赖APP: django.contrib.auth django.contrib.contenttyp ...

  9. 【乱搞】【CF1095E】 Almost Regular Bracket Sequence

    Description 给定一个长度为 \(n\) 的小括号序列,求有多少个位置满足将这个位置的括号方向反过来后使得新序列是一个合法的括号序列.即在任意一个位置前缀左括号的个数不少于前缀右括号的个数, ...

  10. SpringMVC接收复杂集合对象(参数)代码示例

    原文: https://www.jb51.net/article/128233.htm SpringMVC接收复杂集合对象(参数)代码示例 更新时间:2017年11月15日 09:18:15   作者 ...