Linux笔记之perf生成火焰图

2024-04-01 20:04
文章标签 linux 笔记 生成 火焰 perf

本文主要是介绍Linux笔记之perf生成火焰图,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Linux笔记之perf生成火焰图

—— 杭州 2024-04-01 中午

文章目录

  • Linux笔记之perf生成火焰图
    • 1.安装perf
    • 2.下载FlameGraph工具
    • 3.方法一:收集进程PID的性能数据
      • 3.1.C++例程(无限循环)
      • 3.2.编译运行,编译时开启调试符号
      • 3.3.运行该例程后找到进程PID
      • 3.4.使用perf工具收集数据
      • 3.5.将perf记录的数据转换为火焰图需要的中间格式
      • 3.6.使用FlameGraph把中间格式文件生成火焰图
      • 3.7.火焰图查看
    • 4.方法二。在运行程序时记录程序的性能事件
      • 4.1.C++例程(非无限循环)
      • 4.2.编译运行,编译时开启调试符号
      • 4.3.使用 perf 来记录程序的性能事件
      • 4.4.将perf记录的数据转换为火焰图需要的中间格式
      • 4.5.使用FlameGraph把中间格式文件生成火焰图
      • 4.6.火焰图查看

1.安装perf

sudo apt-get install linux-tools-$(uname -r) linux-tools-generic

2.下载FlameGraph工具

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

3.方法一:收集进程PID的性能数据

3.1.C++例程(无限循环)

例:无限循环,直到接收到用户输入才停的C++例程

#include <iostream>
#include <thread>
#include <atomic>
#include <cmath>// Atomic flag to control the execution of the CPU-intensive task
std::atomic<bool> runTask(true);// Function that simulates a CPU-intensive task
void cpuIntensiveTask() {double result = 0.0;while (runTask.load()) { // Loop until the flag is set to falsefor (unsigned int i = 0; i < 1000000; ++i) {result += std::sin(i) * std::cos(i);}}std::cout << "Result of the computation: " << result << std::endl;
}int main() {std::cout << "Starting a long-running CPU-intensive task in a thread." << std::endl;// Start the CPU-intensive task in a separate threadstd::thread worker(cpuIntensiveTask);// Wait for user input to end the taskstd::cout << "Press enter to stop the task..." << std::endl;std::cin.get();// Signal the task to stop and wait for the thread to finishrunTask.store(false);worker.join();std::cout << "Task stopped." << std::endl;return 0;
}

3.2.编译运行,编译时开启调试符号

g++ -g -O2 cpu_task.cpp -o cpu_task -lpthread

3.3.运行该例程后找到进程PID

ps -aux | grep cpu_task

在这里插入图片描述

3.4.使用perf工具收集数据

sudo perf record -F 99 -p PID -g -- sleep 30

在这里插入图片描述

3.5.将perf记录的数据转换为火焰图需要的中间格式

sudo perf script > out.perf
或
sudo perf script -i perf.data> out.perf

在这里插入图片描述

3.6.使用FlameGraph把中间格式文件生成火焰图

./stackcollapse-perf.pl < ../out.perf | ./flamegraph.pl > out.svg

在这里插入图片描述

3.7.火焰图查看

在这里插入图片描述

4.方法二。在运行程序时记录程序的性能事件

4.1.C++例程(非无限循环)

例:非无限循环的C++例程

#include <iostream>
#include <thread>
#include <cmath>// Function that simulates a CPU-intensive task
void cpuIntensiveTask() {double result = 0.0;for (unsigned int i = 0; i < 100000000; ++i) {result += std::sin(i) * std::cos(i);}std::cout << "Result of the computation: " << result << std::endl;
}int main() {std::cout << "Starting a CPU-intensive task in a thread." << std::endl;std::thread worker(cpuIntensiveTask);worker.join();std::cout << "Completed the CPU-intensive task." << std::endl;return 0;
}

4.2.编译运行,编译时开启调试符号

g++ -g -O2 main2.cc -o main2 -lpthread

4.3.使用 perf 来记录程序的性能事件

sudo perf record -g ./main2

在这里插入图片描述

4.4.将perf记录的数据转换为火焰图需要的中间格式

sudo perf script -i perf.data> out.perf

4.5.使用FlameGraph把中间格式文件生成火焰图

../../FlameGraph/stackcollapse-perf.pl < out.perf | ../../FlameGraph/flamegraph.pl > out.svg

4.6.火焰图查看

在这里插入图片描述

这篇关于Linux笔记之perf生成火焰图的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/868024

相关文章

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

Python使用qrcode库实现生成二维码的操作指南

《Python使用qrcode库实现生成二维码的操作指南》二维码是一种广泛使用的二维条码,因其高效的数据存储能力和易于扫描的特点,广泛应用于支付、身份验证、营销推广等领域,Pythonqrcode库是... 目录一、安装 python qrcode 库二、基本使用方法1. 生成简单二维码2. 生成带 Log

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

Linux Mint Xia 22.1重磅发布: 重要更新一览

《LinuxMintXia22.1重磅发布:重要更新一览》Beta版LinuxMint“Xia”22.1发布,新版本基于Ubuntu24.04,内核版本为Linux6.8,这... linux Mint 22.1「Xia」正式发布啦!这次更新带来了诸多优化和改进,进一步巩固了 Mint 在 Linux 桌面

LinuxMint怎么安装? Linux Mint22下载安装图文教程

《LinuxMint怎么安装?LinuxMint22下载安装图文教程》LinuxMint22发布以后,有很多新功能,很多朋友想要下载并安装,该怎么操作呢?下面我们就来看看详细安装指南... linux Mint 是一款基于 Ubuntu 的流行发行版,凭借其现代、精致、易于使用的特性,深受小伙伴们所喜爱。对

什么是 Linux Mint? 适合初学者体验的桌面操作系统

《什么是LinuxMint?适合初学者体验的桌面操作系统》今天带你全面了解LinuxMint,包括它的历史、功能、版本以及独特亮点,话不多说,马上开始吧... linux Mint 是一款基于 Ubuntu 和 Debian 的知名发行版,它的用户体验非常友好,深受广大 Linux 爱好者和日常用户的青睐,

Linux(Centos7)安装Mysql/Redis/MinIO方式

《Linux(Centos7)安装Mysql/Redis/MinIO方式》文章总结:介绍了如何安装MySQL和Redis,以及如何配置它们为开机自启,还详细讲解了如何安装MinIO,包括配置Syste... 目录安装mysql安装Redis安装MinIO总结安装Mysql安装Redis搜索Red

Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南

《Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南》在日常数据处理工作中,我们经常需要将不同Excel文档中的数据整合到一个新的DataFrame中,以便进行进一步... 目录一、准备工作二、读取Excel文件三、数据叠加四、处理重复数据(可选)五、保存新DataFram