linux cpu使用率_linux服务器程序性能调试

ae4c4cf589ace8e630a5fc5cd21865b4.png

linux服务器程序性能调试


CPU

CPU使用率:除了空闲时间外的其他时间占总 CPU 时间的百分比

平均CPU使用率:1-(新得空闲时间-老空闲时间)/(总新的CPU时间-总旧的CPU时间)

注:我们前面介绍的性能分析命令都是间隔一段时间的平均 CPU 使用率,所以要注意间隔时间的设置


perf 简介及安装

  • Perf 是内置于Linux 内核源码树中的性能剖析(profiling)工具。它基于事件采样原理,以性能事件为基础,支持针对处理器相关性能指标与操作系统相关性能指标的性能剖析
  • 测试perf是否安装

caee1cc541fe0c12e469e3baad62ea19.png
  • 使用apt install linux-tools-common安装

d268fd2e777fc93fc8da03d67c65942d.png
  • 再次测试perf

d1d94ff4296abec96003486930565553.png
  • 根据提示输入apt-get install linux-tools-4.4.0-151-generic linux-cloud-tools-4.4.0-151-generic

9ff9e054262e73ec26ace2088316e9ad.png

安装成功


  • 参数
    -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以及进程使用情况:

0d9b2e8a01ce0c31f86ee99f6c4106fd.png

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

e108bf78dcce2a212486140131a33630.png

通过perf来分析,我们得出了造成CPU过高的原因是fun函数导致的;

在以后的工作中,我们需要熟悉的掌握这个命令进程程序分析;

当然,只要我们定位了函数,我们可以使用GDB在开发环境中进行定位或者分析代码;


想了解学习更多C++后台服务器方面的知识,请关注: 微信公众号:====CPP后台服务器开发====


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值