33.perf工具使用

文章目录

    • 基本介绍
    • `perf`命令使用
      • reference


欢迎访问个人网络日志🌹🌹知行空间🌹🌹


基本介绍

Perf(Performance Counters for Linux,性能计数器子系统)是一个Linux性能分析工具,用于分析系统和应用程序的运行时性能。这个工具位于 Linux 内核源代码树中,具体位置在 tools/perf 目录下。虽然它是一个用户空间的应用程序,但却是唯一一个被包含在 Linux 内核源码中的复杂用户软件。

Perf可以帮助开发人员和系统管理员进行函数级和指令级的热点查找,可以用来分析程序中热点函数的CPU占用率,了解CPU性能计数器、内核跟踪点和硬件事件等信息,从而找到性能瓶颈,优化软件性能并诊断问题。

通过 perf 命令,我们可以获得系统在运行过程中的各种性能数据,例如 CPU 利用率、内存使用情况、磁盘 I/O 等。perf 可以用于多个方面的性能分析,以下是一些常用的用途:

  • CPU 性能分析,通过 perf命令,可以监测 CPU 的使用率、上下文切换次数、缓存命中率等指标,可以帮助开发者找出 CPU 性能瓶颈,优化程序的运行效率。
  • 内存性能分析perf 命令可以监测内存的使用情况,例如内存泄漏、内存碎片等问题,可以帮助开发者优化内存的管理,提高系统的稳定性。
  • 函数级别采样perf可以对程序进行函数级别的采样,从而了解程序的性能瓶颈在哪里。其基本原理是每隔一个固定时间,CPU 会产生一个中断,记录当前是哪个进程、哪个函数,然后给对应的进程和函数加一个统计值,从而知道 CPU 在某个进程或某个函数上花费了多少时间。

如果系统没有安装Perf,安装方式为:

sudo apt install linux-tools-common linux-tools-generic

查看是否安装成功:

perf --version
# perf version 5.15.148

权限设置,默认运行perf命令需要sudo权限,可以通过修改/etc/sysctt.conf文件进行设置

sudo vi /etc/sysctl.conf
# add line
kernel.perf_event_paranoid = 0

perf命令使用

命令格式为:

perf <options> subcommand <options/arguments>

perf支持很多subcommand选项,常用的子命令有:

  • annotate读取perf.data,展示带注释代码,实际使用发现展示的汇编代码
sudo perf annotate -f# Percent│       xor    %r15d,%r15d
#        │       lea    0x9(%rsp),%rbp
#        │       testb  $0x3,0x90(%rsp)
#        │     ↓ je     96
#        │       swapgs
#        │       nop
#        │       xchg   %ax,%ax
#        │       mov    %cr3,%rax
#        │       bts    $0x3f,%rax
#        │       and    $0xffffffffffffe7ff,%rax
#        │       mov    %rax,%cr3
#        │       xchg   %ax,%ax
#        │       mov    $0x48,%ecx
  • list,展示perf命令可以用来评估程序性能的事件
sudo perf list -h# Usage: perf list [<options>] [hw|sw|cache|tracepoint|pmu|sdt|metric|metricgroup|event_glob]

通过上面的命令可以查看事件类型,hwhardware硬件相关事件,PMUPerformance Monitoring Unit相关事件等

  • record,记录程序运行时的数据
sudo perf record -e cpu-clock -aR sleep 10# [ perf record: Woken up 1 times to write data ]
# [ perf record: Captured and wrote 0.002 MB perf.data (~150 samples) ]
  • report,展示perf命令记录的数据
sudo perf report -i perf.data
  • stat查看具体某个事件相关的统计结果
sudo perf stat -e cpu-clock -aR sleep 10#  Performance counter stats for 'sleep 10':#               1.13 msec cpu-clock                 #    0.000 CPUs utilized          #       10.002228914 seconds time elapsed#        0.001793000 seconds user
#        0.000000000 seconds sys

statrecord子命令的主要区别是record会将结果保存到perf.data文件中,而stat是直接展示结果。

  • top是直接展示整个系统的CPU内存等使用情况
  • script读取perf.data数据,并展示迹输出trace out
子命令作用
annotate汇编代码及注释
list查看所有事件
stat查看某事件相关的性能数据
record录制某事件相关的性能数据,并保存perf.data文件
report加载perf.data文件
top系统相关的性能数据
scriptperf.data相关的trace out

使用perf命令追踪一个正在运行的进程:

sudo perf stat --pid <pid>

reference

1.https://phoenixnap.com/kb/linux-perf#:~:text=The%20Linux%20perf%20tool%20is,and%20analyzing%20CPU%20event%20data.
2.https://cloud.tencent.com/developer/article/2228048

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

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

相关文章

分析 Base64 编码和 URL 安全 Base64 编码

前言 在处理数据传输和存储时&#xff0c;Base64 编码是一种非常常见的技术。它可以将二进制数据转换为文本格式&#xff0c;便于在文本环境中传输和处理。Go 语言提供了对标准 Base64 编码和 URL 安全 Base64 编码的支持。本文将通过一个示例代码&#xff0c;来分析这两种编码…

前端开发-添加公用的ts文件,并在Vue文件中引用

一般我们把页面要用的公用函数写在一个ts文件中 通过调用这个ts文件让我们可以在vue文件中使用函数 Eg&#xff1a;我们现在创建一个formRules.ts文件 然后在我们需要调用该函数体的vue文件中 import { required } from "/utils/formRules";有可能语法一开始会提示…

Phobos勒索病毒:最新变种phobos袭击了您的计算机?

一、导言 在数字化浪潮中&#xff0c;网络安全问题日益凸显&#xff0c;而.Phobos勒索病毒无疑是其中的隐形杀手。它潜伏在网络的每一个角落&#xff0c;等待着合适的时机对目标发动致命一击。本文将深入探讨.Phobos勒索病毒的新特点、传播途径&#xff0c;并提出一系列创新的…

C++面试题记录(网络)

TCP与UDP区别 1. TCP面向连接&#xff0c;UDP无连接&#xff0c;所以UDP数据传输效率更高 2.UDP可以支持一对一、一对多、多对一、多对多通信&#xff0c;TCP只能一对一 3. TCP需要在端系统维护连接状态&#xff0c;包括缓存&#xff0c;序号&#xff0c;确认号&#xff0c;…

防火墙——域网络、专用网络、公用网络

在防火墙设置中&#xff0c;域网络、专用网络和公用网络是指计算机连接到网络时所处的不同环境。每种环境都有不同的安全级别和配置。 1、域网络&#xff08;宽松&#xff09; 域网络是指计算机加入了一个Windows域&#xff08;Domain&#xff09;环境&#xff0c;这通常在企业…

程序员的那些经典段子

哈喽&#xff0c;大家好&#xff0c;我是明智&#xff5e; 本周咱们已经解决了在面试中经常碰到的OOM问题&#xff1a; 《美团一面&#xff0c;发生OOM了&#xff0c;程序还能继续运行吗&#xff1f;》 《美团一面&#xff1a;碰到过OOM吗&#xff1f;你是怎么处理的&#xff1…

白嫖的在线工具类宝藏网站清单,快点击进来收藏一波

简单整理了一下自己日常经常使用的10个免费工具网站&#xff0c;建议点赞关注收藏&#xff0c;快点分享给小伙伴们&#xff01; 1.奶牛快传:用户体验更好的网盘工具。 https://cowtransfer.com/ 今年开始使用的一款网盘工具&#xff0c;和百度网盘类似,叫奶牛快传&#xff0c;如…

【设计模式】——装饰模式(包装器模式)

&#x1f4bb;博主现有专栏&#xff1a; C51单片机&#xff08;STC89C516&#xff09;&#xff0c;c语言&#xff0c;c&#xff0c;离散数学&#xff0c;算法设计与分析&#xff0c;数据结构&#xff0c;Python&#xff0c;Java基础&#xff0c;MySQL&#xff0c;linux&#xf…

数据结构--二叉搜索树

目录 二叉搜索树的概念 二叉树的实现 结点类 函数接口总览 实现二叉树 二叉搜索树的应用 K模型 KV模型 二叉搜索树的性能分析 二叉搜索树的概念 二叉搜索树&#xff08;Binary Search Tree&#xff0c;简称BST&#xff09;是一种特殊的二叉树&#xff0c;其具有以下几…

数据库(6)——数据类型

SQL标准常用的数据类型有&#xff1a; 数据类型含义CHAR(n),CHARACTER(n)长度为n的定长字符串VARCHAR&#xff08;n&#xff09;最大长度为n的变长字符串CLOB字符串大对象BLOB二进制大对象SMALLINT2字节 短整数INT , INTEGER4字节 整数BIGINT8字节 大整数FLOAT(n)精度为n的浮点…

6818 android 修改开机 logo, 编译脚本分析

问题&#xff1a; 客户需要去掉 android5.1 的开机logo. 说明&#xff1a; 对于Android5.1 来说&#xff0c;uboot 与kernel 的logo 是一个。 过程&#xff1a; 其实对于开机logo 的修改很简单&#xff0c;直接参考厂家手册就可以了。 这是 android4.4 的开机logo 的修改&…

设计一个代办功能模块

目录 1. 需求分析2. 数据库设计用户表&#xff08;Users Table&#xff09;代办任务表&#xff08;Tasks Table&#xff09;订单表&#xff08;Orders Table&#xff09;评价表&#xff08;Reviews Table&#xff09; 3. 功能实现创建代办任务前端部分后端部分 接受代办任务前端…

产品经理-需求收集(二)

1. 什么是需求 指在一定的时期中&#xff0c;一定场景中&#xff0c;无论是心理上还是生理上的&#xff0c;用户有着某种“需要”&#xff0c;这种“需要”用户自己不一定知道的&#xff0c;有了这种“需要”后用户就有做某件事情的动机并促使达到其某种目的&#xff0c;这也就…

FPGA实现多路并行dds

目录 基本原理 verilog代码 仿真结果​ 基本原理 多路并行dds&#xff0c;传统DDS的局限性在于输出频率有限。根据奈奎斯特采样定理&#xff0c;单路DDS的输出频率应小于系统时钟频率的一半。但是在很多地方&#xff0c;要使采样率保持一致&#xff0c;所以&#xff0c;为了…

【CTF Web】CTFShow web7 Writeup(SQL注入+PHP+进制转换)

web7 1 阿呆得到最高指示&#xff0c;如果还出问题&#xff0c;就卷铺盖滚蛋&#xff0c;阿呆心在流血。 解法 注意到&#xff1a; <!-- flag in id 1000 -->拦截很多种字符&#xff0c;连 select 也不给用了。 if(preg_match("/\|\"|or|\||\-|\\\|\/|\\*|\…

路径规划算法的复杂度

通常通过以下指标来衡量&#xff1a; 时间复杂度&#xff1a;这是评估算法执行所需时间的量度。它通常用大O符号表示&#xff0c;给出了算法运行时间随着输入规模增长的增长率。例如&#xff0c;一个时间复杂度为O(n^2)的算法在处理大规模输入时会比时间复杂度为O(n log n)的算…

PostgreSQL的扩展(extensions)-常用的扩展之pg_plan_advsr

PostgreSQL的扩展&#xff08;extensions&#xff09;-常用的扩展之pg_plan_advsr pg_plan_advsr 是 PostgreSQL 社区中的一个扩展&#xff0c;用于分析和改进查询执行计划。它能够自动识别哪些查询执行缓慢&#xff0c;并提供优化建议&#xff0c;以提高查询性能。pg_plan_ad…

AI时代存储大战,NAND闪存市场风云再起!

随着人工智能&#xff08;AI&#xff09;相关半导体对高带宽存储&#xff08;HBM&#xff09;需求的推动&#xff0c;NAND闪存市场也感受到了这一趋势的影响。 据《Business Korea》援引行业消息来源称&#xff0c;NAND闪存市场的竞争正在加剧&#xff0c;而存储巨头三星和SK海…

CSP俄罗斯方块(简单易懂)

开始将题目理解成了&#xff0c;开始的列应该是从输入图案的最左端开始计算&#xff0c;将前面所有的空列都删掉&#xff0c;代码如下&#xff1a; #include<bits/stdc.h> using namespace std; const int N 1e410; const int M 1e510; int a[20][20]; int b[5][5];int…

Redis的持久化方式:

Redis提供了两种数据持久化的方式&#xff1a; RDB 该机制是指在指定的时间间隔内将内存中的数据集快照写入磁盘。 AOF 该机制将以日志的形式记录服务器所处理的每一个写操作。 在Redis服务器启动之初会读取文件来重新构建数据库&#xff0c;以保证启动后数据库中的数据是完…