了解与生成火焰图

目录

一、如何看懂火焰图

1、基本特征

2、基本分类

二、如何生成火焰图

1、捕获调用栈

2、折叠栈

3、转换为 svg 格式

4、展示 svg


一、如何看懂火焰图

1、基本特征

(1)纵轴:即每一列代表一个调用栈,每一个格子代表一个函数,调用顺序从下到上,火焰的火苗尖部就是CPU正在执行的操作。

(2)横轴:格子的宽度代表其在采样中出现频率(消耗的时间),所以格子的宽度越大,说明它是瓶颈原因的可能性就越大。on-cpu 火焰图横轴是指 cpu 占用时间,off-cpu 火焰图横轴则代表阻塞时间。

(3)颜色本身没有什么意义

(4)快速查看:主要看那些比较宽大的火苗,特别是那些平头的火苗;

2、基本分类

类型

横轴

纵轴

方案

采样

ON-CPU火焰图

CPU占用时间

调用栈

找出 CPU 占用高的函数,分析代码热路径

固定频率采样 CPU 调用栈

OFF-CPU火焰图

阻塞时长

调用栈

考虑 IO 或网络等阻塞场景;考虑锁竞争或死锁等问题

固定频率采样阻塞事件调用栈

内存火焰图

内存申请/释放函数的调用次数

调用栈

内存泄漏问题;内存占用过高的问题

存在四种方式:

(1)跟踪 malloc/free

(2)跟踪 brk;

(3)跟踪 mmap;

(4)跟踪 页错误;

Hot/Cold火焰图

综合 ON-CPU和OFF-CPU两种

调用栈

结合ON-CPU和OFF-CPU两种

结合ON-CPU和OFF-CPU两种

二、如何生成火焰图

推荐 GitHub - brendangregg/FlameGraph: Stack trace visualizer 工具

1、捕获调用栈

        使用 linux 系统自带的 perf 工具进行性能分析,返回 CPU 正在执行的函数及其调用栈。

# 对进程 13204 进行持续 30 s 每秒 99 次的采样,并记录。注意是每个 CPU 都会执行采样。
perf record -F 99 -p 15809-g -- sleep 30
# 转换二进制数据为文本格式,若 out.perf 为空大概是没有足够的采用数据
perf script -v > out.perf

        perf 作为 linux 默认的性能分析工具,功能强大,推荐具体分析其中参数。

2、折叠栈

# 转换为折叠后的栈文件
# 或不是使用 perf 性能分析工具,则需要使用别的折叠工具。
./FlameGraph/stackcollapse-perf.pl out.perf > out.folded

3、转换为 svg 格式

# 继续转换为 svg 格式
./FlameGraph/flamegraph.pl out.folded > mongod.svg

4、展示 svg

使用浏览器打开 svg 文件即可

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/789602.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【跨境商家福音】一款性价比高、好用的跨境选品工具

亚马逊、速卖通、Shopee 、Lazada、美客多、eBay、SHEIN、Temu、Tiktok、shopify等跨境电商平台,其用户消费喜好多样,涵盖服装、美妆、电子产品等多个品类。而店雷达作为一款基于大数据和人工智能技术的电商分析工具,为商家提供了强大的选品和…

宁盾身份域管与Coremail邮件系统完成兼容互认证,持续深化信创布局

在信创国产化改造的背景下,企业邮箱的替换是许多党政、央国企、金融、制造企业面临的重要任务。为了满足企业对国产邮箱、OA等其他应用、终端实现统一身份认证,宁盾国产化身份域管与 Coremail XT 安全增强电子邮件系统 V5.0、V6.0 完成了产品兼容互认证&…

破解密码:掌握2024年的营销归因

Cracking the Code: Mastering Marketing Attribution in 2024 营销归因是识别哪些营销渠道和触及点有助于销售或转化的过程。随着消费者继续通过多个渠道与品牌互动,掌握营销归因对企业来说变得越来越重要。在这篇文章中,我们将探讨破解代码和有效衡量…

游戏运营分析:如何在新游戏上线初期实现精细化运营?

一、背景介绍 在当今的手游市场中,每一款新游戏的发布都如同踏上一段充满未知与挑战的探险之旅。游戏刚上线时,运营情况往往如同飘摇的小船,随时可能受到风浪的侵袭。此时,如何准确地找到问题所在,为游戏的健康运营和持…

【Python项目】AI动物识别工具

目录 背景 技术简介 系统简介 界面预览 背景 成像技术在全球科技发展中扮演了关键角色。在科学研究领域,拍摄所得的图像成为了一种不可或缺的研究工具。特别是在生态学与动物学研究中,鉴于地球的广阔地域和多样的气候条件,利用图像技术捕…

【Qt 学习笔记】输入框实现helloworld | QLineEdit的使用

博客主页:Duck Bro 博客主页系列专栏:Qt 专栏关注博主,后期持续更新系列文章如果有错误感谢请大家批评指出,及时修改感谢大家点赞👍收藏⭐评论✍ 输入框实现helloworld | QLineEdit的使用 文章编号:Qt 学习…

pytest接口自动化框架实际应用

一、自动化实现的目标 1、测试用例数据驱动。 2、测试数据和用例分离。 3、每个测试用例拥有专属的测试数据有明确的测试初始状 4、测试用例的执行不依赖其他测试用例执行所产生的数据 5、建立体系化测试数据,进行数据依赖管理,覆盖全部测试分层策略要求…

PCB的电气/物理特性检查项目需思考的问题

在PCB设计、制造和装配过程中,为确保产品性能和质量,电子工程师必须进行电气特性和物理特性检查,然而对很多新人来说如何高效进行检查是个难题,所以下面将分别探讨这些检查时需要考虑的问题。 1、PCB电气特性检查项目①导线参数分…

CLIP 图文检索,相似度计算

CLIP 是OpenAI提出的神经网络,它可以从自然语言监督中有效地学习视觉概念。 CLIP 可以应用于任何视觉分类基准,只需提供要识别的视觉类别的名称,类似于 GPT-2 和 GPT-3 的“零样本”功能。 相关paper 用法可以参考github 这里举几个使用CLI…

CTK插件框架学习-信号槽(05)

CTK插件框架学习-事件监听(04)https://mp.csdn.net/mp_blog/creation/editor/137171155 一、主要流程 信号发送者告诉服务要发送的信号信号发送者发送信号信号接收者告诉服务当触发某个订阅的主题时通知槽函数信号接收者处理槽函数信号槽参数类型必须为(const ctk…

[RK3588-Android12] 调试MIPI-双通道-压缩屏(Video Mode/MIPI Dphy 8Lane/DSC 144HZ)

问题描述 被测屏幕:小米Pad6 分辨率:1800X2880 模式:Video Mode/MIPI Dphy 8Lane/DSC 144HZ PPS: 11 00 00 89 30 80 0B 40 03 84 00 14 01 C2 01 C2 02 00 01 F4 00 20 01 AB 00 06 00 0D 05 7A 06 1A 18 00 10 F0 03 0C 20 00 06 0B 0B 33…

linux进程退出之exit与_exit

linux进程退出之exit与_exit _exitexit流程清理函数atexit()函数:on_exit()函数: _exit /* Terminate program execution with the low-order 8 bits of STATUS. */ /** status参数定义了进程的终止状态,父进程可以通过wait(&am…

腾讯云邮件推送功能有哪些?如何有效使用?

腾讯云邮件推送如何设置?怎么用邮件推送做高效营销? 腾讯云作为业界领先的云服务提供商,其邮件推送功能在便捷性、稳定性和安全性上都有着出色的表现。那么,腾讯云邮件推送功能究竟有哪些呢?让AokSend来探个究竟。 腾…

基于SpringBoot+微信小程序的图书借阅管理系统(包运行调试)

介绍 系统介绍 是一套图书借阅管理系统,包括用户小程序以及后台管理系统。 前台商城系统包含用户注册登录、首页门户、图书查询、在线借阅、个人中心、我的信息、我的借阅、押金充值。 后台管理系统包含统计分析、用户管理、分类管理、图书管理、借阅管理、管理员…

HarmonyOS NEXT应用开发之@Observed装饰器和\@ObjectLink装饰器:嵌套类对象属性变化

上文所述的装饰器仅能观察到第一层的变化,但是在实际应用开发中,应用会根据开发需要,封装自己的数据模型。对于多层嵌套的情况,比如二维数组,或者数组项class,或者class的属性是class,他们的第二…

教育信创 | 云轴科技ZStack联合飞腾发布全场景教育信创白皮书

随着数字化时代的到来,教育行业正面临着前所未有的挑战与机遇。为了推动教育行业的数字化转型和信创人才培养,云轴科技ZStack联合飞腾于3月28日正式发布了《教育行业数字化自主创新飞腾生态解决方案白皮书》(简称《教育白皮书》)。…

新能源汽车充电桩主板产业链解析

新能源汽车充电桩主控制板,简称汽车充电桩主板,是充电桩设施的核心部件,主要负责控制充电桩的整体运行和管理充电过程。了解汽车充电桩主板的整体产业链是非常重要的,这可以帮助您更好地了解供应链、采购渠道以及行业发展趋势。 产…

抓住信号如此简单,WeTrade一个指标1分钟轻松解决

在交易中是不是有这样的困惑,没有清晰的计算逻辑还抓不住交易的信号,这样的投资者有福了,今天WeTrade众汇分享一个指标1分钟轻松解决这个困惑。 ROC全称Rate of Change,中文名为变动速度指标或变动率指标,它以百分比的…

Java就近原则和this关键字

Java 中的就近原则和 this 关键字有着密切的关系,特别是在处理成员变量与方法参数同名的情况下。就近原则指的是在同一作用域下,优先使用最近声明的变量或参数。 在 Java 中,如果一个方法的参数与类的成员变量同名,为了明确指示要…

大数据实验四-MapReduce编程实践

一.实验内容 MapReduce编程实践: 使用MapReduce实现多个文本文件中WordCount词频统计功能,实验编写Map处理逻辑、编写Reduce处理逻辑、编写main方法。 二.实验目的 1、通过实验掌握基本的MapReduce编程方法。 2、实现统计HDF…