jdk自带诊断命令

124 阅读3分钟

本文已参与「新人创作礼」活动,一起开启掘金创作之路。

虚拟机工具jps

  • jps (JVM Process Status Tool)是其中的典型jvm工具
  • 实战使用
    • jps -l 输出主类的全名,如果进程执行的是Jar包则输出Jar路径
    • jps -v 输出虚拟机进程启动时JVM参数

jstat命令

  • Jstat (JVM Statistics Monitoring Tool)是用于监视虚拟机各种运行状态信息的命令行工具。它可以显示本地或者远程-虚拟机进程中的类装载、内存、垃圾收集、JIT 编译等运行数据,在没有 GU 图形界面,只提供了纯文本控制台环境的服务器上,它将是运行期定位虚拟机性能问题的首选工具
  • jstat命令使用
jstat -gc 2764 250 20   //2764表示进程id ,250表示250毫秒打印一次 ,20表示一共打印20次

 S0C:第一个幸存区的大小
 S1C:第二个幸存区的大小
 S0U:第一个幸存区的使用大小
 S1U:第二个幸存区的使用大小
 EC:伊甸园区的大小
 EU:伊甸园区的使用大小
 OC:老年代大小
 OU:老年代使用大小
 MC:方法区大小
 MU:方法区使用大小
 CCSC:压缩类空间大小
 CCSU:压缩类空间使用大小
 YGC:年轻代垃圾回收次数
 YGCT:年轻代垃圾回收消耗时间
 FGC:老年代垃圾回收次数
 FGCT:老年代垃圾回收消耗时间
 GCT:垃圾回收消耗总时间

jinfo命令

  • jinfo (Configuration Info for Java)的作用是实时地查看和调整虚拟机各项参数
  • jinfo命令使用
jinfo -flag CMSInititingOccupancyFraction 1444

jmap常用命令

  • Jmap (Memory Map for Java)命令用于生成堆转储快照。如果不使用 jmap 命令,要想获取 Java 堆转储快照,还有一些比较“暴力”的手段:-XX: +HeapDumpOnOutOfMemoryError 参数,可以让虚拟机在 OOM 异常出现之后自动生成 dump 文件,用于系统复盘环节

  • jmap常用命令

    • -dump:生成 Java 堆转储快照。格式为:-dump: format=b, file=

    jmap -dump:format=b,file=/Users/lelontar/deskTop

    • -histo:显示堆中对象统计信息,包括类、实例数量、合计容量

    jmap -histo pid|less

    B: byte
    I: int
    C: char
    这三个类型在最前边很正常
    

jhat命令

  • 实战oom,在idea的edit configration中配置中vm处设置-Xmx40m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/Users/lelontar/Desktop
  • oom代码
public class JHatTest {

  public static void main(String[] args) {
    List<byte[]> byteList = new ArrayList<>();
    for (; ; ) {
      byte[] bytes = new byte[1024 * 1024 * 4];
      byteList.add(bytes);
    }
  }
}
  • jhat 文件命
  • 查看地址localhost:7000,找到Other Queries,主要看Show heap histogram
  • 特点:
    • jhat分析工作是一个耗时而且消耗硬件资源的过程
    • jhat 的分析功能相对来说比较简陋

Jstack命令

jstack是什么?
  • Jstack (Stack Trace for Java)命令用于生成虚拟机当前时刻的线程快照
常用命令
  • jstack -l pid
  • jstack -F 当正常输出的请求不被响应时,强制输出线程堆栈 Force

Jconsole命令

jconsole是什么?
  • JConsole (Java Monitoring and Management Console)是一种基于 JMX 的可视化监视、管理工具,它管理部分的功能是针对 JMXMBean 进行管理,由于 MBean 可以使用代码、中间件服务器的管理控制台或者所有符合 JMX 规范的软件进行访问
特点:
  • jconsole集成了线程与内存的可视化展示
直接在控制台输入jconsole就可以查看你想看的运行程序

可视化虚拟机工具VisualVM

/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/bin/jvisualvm