linux服务器程序性能调试
CPU
CPU使用率:除了空闲时间外的其他时间占总 CPU 时间的百分比
平均CPU使用率:1-(新得空闲时间-老空闲时间)/(总新的CPU时间-总旧的CPU时间)
注:我们前面介绍的性能分析命令都是间隔一段时间的平均 CPU 使用率,所以要注意间隔时间的设置
perf 简介及安装
Perf 是内置于Linux 内核源码树中的性能剖析(profiling)工具。它基于事件采样原理,以性能事件为基础,支持针对处理器相关性能指标与操作系统相关性能指标的性能剖析
测试perf是否安装

使用
apt install linux-tools-common安装
再次测试
perf
根据提示输入
apt-get install linux-tools-4.4.0-151-generic linux-cloud-tools-4.4.0-151-generic
安装成功
参数
-C 指定统计的CPU核心编号,不指定时统计全部核心(等价于-a)
-e 指定统计事件
-p 只统计特定pid指定的进程中产生的事件
-t 只统计特定tid指定的线程中产生的事件
-K 隐藏内核中的函数符号
-U 隐藏用户态的函数符号
-g perf record工具专用的参数,记录函数的调用栈信息
实践测试
首先,写一段让CPU达到接近100%的代码,while就可以了;
#include <iostream>
using namespace std;
int count = 0;
void fun()
{
while(1)
{
count++;
}
}
int main()
{
fun();
return 0;
}
编译:
g++ test.cpp -o test执行 :
./test
使用htop查看CPU以及进程使用情况:

得到进程号,我们使用perf来看一下具体导致CPu高的函数:perf top -g -p 22430

通过perf来分析,我们得出了造成CPU过高的原因是fun函数导致的;
在以后的工作中,我们需要熟悉的掌握这个命令进程程序分析;
当然,只要我们定位了函数,我们可以使用GDB在开发环境中进行定位或者分析代码;
想了解学习更多C++后台服务器方面的知识,请关注: 微信公众号:====CPP后台服务器开发====

本文详细介绍Linux服务器上使用Perf工具进行程序性能调试的方法。Perf是内置于Linux内核的性能剖析工具,支持处理器和操作系统性能指标分析。文章通过实例演示如何定位导致CPU使用率过高的函数,并提供GDB等进一步分析手段。
1568

被折叠的 条评论
为什么被折叠?



