Jcmd 分析jvm虚拟机并解析jfr文件

Jcmd 分析jvm虚拟机

在JDK 1.7之后,新增了一个命令行工具jcmd。它是一个多功能工具,可以用来导出堆,查看java进程,导出线程信息,执行GC等。

开启JFR需要三步:

  • 创建一个包含了你自己配置的JFR模板文件。运行 jmc, 然后 窗口→飞行记录模板管理 菜单。准备好档案后,就可以导出文件,并移动到要排查问题的环境中。

  • 由于JFR需要JDK的商业证书,这一步需要解锁jdk的商业特性。

jcmd <PID> VM.unlock_commercial_features

  • 启动jcmd

以demo应用为例:

jcmd <PID> JFR.start name=test1 duration=10s settings=template filename=output1.jfr

收集完监控数据后用jmc打开

UI界面展示:

output1.jfr是一个二进制文件,下面讲下如何用脚本分析.

分析output1.jfr 需要用到https://github.com/chrishantha/jfr-flame-graph

install-mc-jars.sh

mvn clean install -U

git clone https://github.com/brendangregg/FlameGraph.git

export FLAMEGRAPH_DIR=/path/to/FlameGraph

通过以下命令转换成可识别的数据文件

火焰图

./create_flamegraph.sh -f recording_13801_1.jfr -i > flamegraph.svg

转为json串

./flamegraph-output.sh json -f recording_13801_1.jfr > resource.json

对json串进行递归分析后可以获得如下数据,key表示具体的函数名,value表示该函数的执行次数样本统计:

时间: 2024-08-26 19:44:38

Jcmd 分析jvm虚拟机并解析jfr文件的相关文章

JVM系列文章(三):Class文件内容解析

作为一个程序员,仅仅知道怎么用是远远不够的.起码,你需要知道为什么可以这么用,即我们所谓底层的东西. 那到底什么是底层呢?我觉得这不能一概而论.以我现在的知识水平而言:对于Web开发者,TCP/IP.HTTP等等协议可能就是底层:对于C.C++程序员,内存.指针等等可能就是底层的东西.那对于Java开发者,你的Java代码运行所在的JVM可能就是你所需要去了解.理解的东西. 我会在接下来的一段时间,和读者您一起去学习JVM,所有内容均参考自<深入理解Java虚拟机:JVM高级特性与最佳实践>(

深入理解JVM虚拟机4:Java class介绍与解析实践

微信公众号[Java技术江湖]一位阿里 Java 工程师的技术小站.作者黄小斜,专注 Java 相关技术:SSM.SpringBoot.MySQL.分布式.中间件.集群.Linux.网络.多线程,偶尔讲点Docker.ELK,同时也分享技术干货和学习经验,致力于Java全栈开发!(关注公众号后回复”Java“即可领取 Java基础.进阶.项目和架构师等免费学习资料,更有数据库.分布式.微服务等热门技术学习视频,内容丰富,兼顾原理和实践,另外也将赠送作者原创的Java学习指南.Java程序员面试指

SAX方式解析XML文件的方法分析

SAX(Simple API for XML)SAX的工作原理简单地说就是对文档进行顺序扫描,当扫描到文档(document)开始与结束.元素(element)开始与结束.文档(document)结束等地方时通知事件处理方法,由事件处理函数做相应动作,然后继续同样的扫描,直至文档结束.SAX解析方式适用于大型文档,因为他的解析是逐行进行不用像DOM中那样为所有节点创建对象,这样效率大大提高,所以虽然它不是W3C标准,但它却得到了广泛认可. 这是一个需要解析的XML文件: <?xml versio

jvm虚拟机(一):jvm内存溢出问题的分析与解决

??学习一下java虚拟机系列,之一 添加运行参数-XX:+HeapDumpOnOutOfMemoryError -Xms30m -Xmx30m -XX:+HeapDumpOnOutOfMemoryError 这个参数会生成堆栈快照,用于定位异常 模拟内存溢出的场景,简单代码: 123456789101112131415161718192021222324252627282930313233 package top.alertcode.demo.jvm; import java.util.Arr

java之jvm学习笔记三(Class文件检验器)

前面的学习我们知道了class文件被类装载器所装载,但是在装载class文件之前或之后,class文件实际上还需要被校验,这就是今天的学习主题,class文件校验器. class文件 校验器,保证class文件内容有正确的内部结构,java虚拟机的class文件检验器在字节码执行之前对文件进行校验,而不是在执行中进行校验 class文件校验器要进行四趟独立的扫描来完成校验工作 class文件校验器分成四趟独立的扫描来完成校验. 第一趟 在装载字节序列的时候进行,这个是校验class文件的结构的合

jvm虚拟机原理1

JVM是虚拟机,也是一种规范,他遵循着冯·诺依曼体系结构的设计原理.冯·诺依曼体系结构中,指出计算机处理的数据和指令都是二进制数,采用存储程序方式不加区分的存储在同一个存储器里,并且顺序执行,指令由操作码和地址码组成,操作码决定了操作类型和所操作的数的数字类型,地址码则指出地址码和操作数.从dos到window8,从unix到ubuntu和CentOS,还有MAC OS等等,不同的操作系统指令集以及数据结构都有着差异,而JVM通过在操作系统上建立虚拟机,自己定义出来的一套统一的数据结构和操作指令

java语言与jvm虚拟机简介

一.java语言 1.1 支持面向对象编程oop 强调支持,因为java同样可以面向过程编程. oop的三大特性是:封装.继承.多态. 封装主要针对成员变量而言,oop的思想要求成员变量均为私有,不应该对外能够访问,一个符合oop思想的类应该只有公共方法对外能够访问: 继承,主要理解继承体系,private.protected.public在继承中的使用场景.理解java是单继承多实现的(与C++的区别): 多态主要指一个类的实例是运行时决定的,而不是声明时决定的.父类 a = new 子类()

初谈JVM虚拟机

学了这么久的Java,一直听说JVM虚拟机是运行所有java程序,但是不知道具体内部结构是怎样,以及它的运行机制是什么.今天刚好看到一篇文章,索性就开始学习. JVM的主要结构: 由上图可以看出,Jvm主要组成有:类加载器.运行数据区.执行引擎.本地方法接口组成.其中运行数据区包含子模块方法区.堆.Java栈.本地方法栈以及寄存器.对于方法区.堆是对所有线程共享的,而其他则是属于当前线程私有. 下面开始一步步剖析JVM........... 1.类加载器(Class loader) 类加载器负责

深入JVM——OOM异常解析

JVM对象访问解析 对象访问过程的内存情况 public void function(){ Object obj = new Object(); } function方法被执行的时候,JVM在JVM栈中为function创建一个栈帧,用于存放function在运行过程中的一些信息. Object obj被执行时,JVM在function方法对应的栈帧中的本地变量表中创建Object类型的引用obj. new Object()被执行时,JVM在堆内存中创建一块Object类型的.包含实例数据值的结