前言:
Linux perf 是 Linux 2.6+ 后内置于内核源码树中的性能剖析(profiling)工具,它基于事件采样,以性能事件为基础,针对 CPU 相关性能指标与操作系统相关性能指标进行性能剖析,可用于性能瓶颈查找与热点代码的定位。包含在 Linux 内核 tools/perf 下,通过命令 perf 实现一组子命令:stat , record , report ,[…],通俗点说也就是Linux都自带这个工具,但最小化安装不包含此工具,需要单独安装,在centos7下,安装此工具的命令是:
yum install perf -y
具体来说,perf 就是是由 Linux 官方提供的系统性能分析工具,perf 包含两部分:perf 命令:用户空间应用程序;perf_events:Linux 内核子系统,主要分析服务器的cpu性能
与其他性能分析工具相比,perf 特别适合 CPU 分析,它能对运行在 CPU 上代码调用栈(stack traces)进行采样,以确定程序在 CPU 上的运行情况,识别和优化代码中的热点。这种 CPU Profiling 能力是基于硬件计数器 (performance monitoring counters,PMC) 实现的,而 PMC 被内核子系统 perf_events 包装成了 Hardware Event。
欧克,简单的用通俗易懂的话来说,如果你有一个新的服务器,比如异构的aarch64服务器,而你对此服务器是否能够正常运行数据库存疑,此时,perf工具会帮助你分析cpu是否可靠,cpu的性能是否能满足你的需求
下面就介绍如何使用perf这个工具来对服务器的cpu做一个体检,以及早发现服务器得cpu运行瓶颈
一、
perf的简易报告模式
简易模式是最常用的一种方式,如果需要在其它服务器上分析本机的cpu性能,只需要把data文件传送到远端就可以了,非常的方便
首先需要记录一段时间内的cpu运行情况,参数是record,会自动在当前目录生成一个数据文件,然后,通过report参数生成cpu运行的报告
此时命令将会hang住,如果服务器比较繁忙,data文件将会增长的比较快,CTRL+c退出记录,并在当前目录下生成perf.data 这个文件,多次执行,会覆盖原文件,但保留一个上次的文件,重命令为perf.data.old 文件
[root@centos2 ~]# perf record
^C[ perf record: Woken up 52 times to write data ]
[ perf record: Captured and wrote 13.518 MB perf.data (285121 samples) ]
生成perf报告:
perf report
由于我这个是虚拟机,没有运行什么服务,因此,cpu负载是非常低的,实际使用中,只需要关注前面几行,当然,在压测的时候,我们也只是关注前面几行就可以了
可以看到,这个服务器只跑了一个postgresql数据库,还有一个vmtool,swap虚拟内存其实是关闭的,但不知道为什么这个perf会显示swap,这就很无语
二、
perf的cpu实时监控模式
cpu实时监控比较多的用在系统出现瓶颈的时候,此时结合此工具可以比较快速的查询出瓶颈原因,该命令类似top命令
perf top -a
输出如下:
可以看到有很多类库占用cpu,因此,如果在系统有瓶颈的时候,看前面几列,看哪个类库占用比较高,自然就是该系统的瓶颈了
不太常用的
perf script
使用 perf script
命令可以打印收集在 perf.data 中的每个样本:
.
剩下的一些参数,基本都用不到,对实际的调试工作并没有多大意义,本文也就不多做介绍了~!!!~~~