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

相关文章

Linux实现查看某一端口是否开放

《Linux实现查看某一端口是否开放》文章介绍了三种检查端口6379是否开放的方法:通过lsof查看进程占用,用netstat区分TCP/UDP监听状态,以及用telnet测试远程连接可达性... 目录1、使用lsof 命令来查看端口是否开放2、使用netstat 命令来查看端口是否开放3、使用telnet

Linux系统管理与进程任务管理方式

《Linux系统管理与进程任务管理方式》本文系统讲解Linux管理核心技能,涵盖引导流程、服务控制(Systemd与GRUB2)、进程管理(前台/后台运行、工具使用)、计划任务(at/cron)及常用... 目录引言一、linux系统引导过程与服务控制1.1 系统引导的五个关键阶段1.2 GRUB2的进化优

C#使用Spire.XLS快速生成多表格Excel文件

《C#使用Spire.XLS快速生成多表格Excel文件》在日常开发中,我们经常需要将业务数据导出为结构清晰的Excel文件,本文将手把手教你使用Spire.XLS这个强大的.NET组件,只需几行C#... 目录一、Spire.XLS核心优势清单1.1 性能碾压:从3秒到0.5秒的质变1.2 批量操作的优雅

Python使用python-pptx自动化操作和生成PPT

《Python使用python-pptx自动化操作和生成PPT》这篇文章主要为大家详细介绍了如何使用python-pptx库实现PPT自动化,并提供实用的代码示例和应用场景,感兴趣的小伙伴可以跟随小编... 目录使用python-pptx操作PPT文档安装python-pptx基础概念创建新的PPT文档查看

Linux查询服务器 IP 地址的命令详解

《Linux查询服务器IP地址的命令详解》在服务器管理和网络运维中,快速准确地获取服务器的IP地址是一项基本但至关重要的技能,下面我们来看看Linux中查询服务器IP的相关命令使用吧... 目录一、hostname 命令:简单高效的 IP 查询工具命令详解实际应用技巧注意事项二、ip 命令:新一代网络配置全

linux安装、更新、卸载anaconda实践

《linux安装、更新、卸载anaconda实践》Anaconda是基于conda的科学计算环境,集成1400+包及依赖,安装需下载脚本、接受协议、设置路径、配置环境变量,更新与卸载通过conda命令... 目录随意找一个目录下载安装脚本检查许可证协议,ENTER就可以安装完毕之后激活anaconda安装更

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

在ASP.NET项目中如何使用C#生成二维码

《在ASP.NET项目中如何使用C#生成二维码》二维码(QRCode)已广泛应用于网址分享,支付链接等场景,本文将以ASP.NET为示例,演示如何实现输入文本/URL,生成二维码,在线显示与下载的完整... 目录创建前端页面(Index.cshtml)后端二维码生成逻辑(Index.cshtml.cs)总结

Linux查询服务器系统版本号的多种方法

《Linux查询服务器系统版本号的多种方法》在Linux系统管理和维护工作中,了解当前操作系统的版本信息是最基础也是最重要的操作之一,系统版本不仅关系到软件兼容性、安全更新策略,还直接影响到故障排查和... 目录一、引言:系统版本查询的重要性二、基础命令解析:cat /etc/Centos-release详

Python实现数据可视化图表生成(适合新手入门)

《Python实现数据可视化图表生成(适合新手入门)》在数据科学和数据分析的新时代,高效、直观的数据可视化工具显得尤为重要,下面:本文主要介绍Python实现数据可视化图表生成的相关资料,文中通过... 目录前言为什么需要数据可视化准备工作基本图表绘制折线图柱状图散点图使用Seaborn创建高级图表箱线图热