0

0

Linux如何查看系统调用延迟_Linux perf性能分析工具入门【调试】

冰火之心

冰火之心

发布时间:2026-01-22 16:48:09

|

409人浏览过

|

来源于php中文网

原创

perf工具可直接采集和统计syscall级别延迟:先用perf record捕获sys_enter/sys_exit事件,再用perf script解析时间差,或用perf probe动态加探针,最后通过perf report分析热点、perf stat统计均值。

linux如何查看系统调用延迟_linux perf性能分析工具入门【调试】

如果您希望分析Linux系统中系统调用的延迟表现,perf工具可直接采集和统计syscall级别的时延分布。以下是使用perf完成该任务的具体操作路径:

一、使用perf record捕获系统调用延迟事件

perf record可基于内核tracepoint机制,对sys_enter和sys_exit事件进行配对采样,从而推导单次系统调用耗时。需启用ftrace backend并确保内核配置支持syscall tracepoints。

1、执行sudo perf record -e 'syscalls:sys_enter_*' -e 'syscalls:sys_exit_*' -a -- sleep 10

2、等待10秒后自动停止记录,生成perf.data文件

3、运行sudo perf script > syscall_trace.log将原始事件流导出为文本

二、使用perf script解析调用延迟

perf script输出包含每个系统调用进入与退出的时间戳(以纳秒为单位),通过脚本可计算差值并筛选高延迟样本。无需额外编译工具,仅依赖perf自带解析能力。

1、执行sudo perf script -F comm,pid,tid,cpu,time,event,ip,sym -F trace:syscalls:sys_enter_* -F trace:syscalls:sys_exit_* > raw_syscall.log

2、提取含时间戳与事件名的行:grep -E "sys_enter_|sys_exit_" raw_syscall.log > filtered.log

3、编写awk脚本对同一pid/tid下相邻的sys_enter_*与对应sys_exit_*行计算时间差

三、使用perf probe动态添加延迟探针

当标准tracepoint未覆盖目标系统调用(如某些架构特定或新引入syscall)时,perf probe可通过内核符号定位入口/出口函数地址,插入kprobe/kretprobe实现毫秒级延迟测量。

1、查询系统调用号对应函数:cat /usr/include/asm-generic/unistd_64.h | grep write

2、添加进入探针:sudo perf probe -x /lib/modules/$(uname -r)/build/vmlinux 'SyS_write %reg' --force

星辰Agent
星辰Agent

科大讯飞推出的智能体Agent开发平台,助力开发者快速搭建生产级智能体

下载

3、添加返回探针:sudo perf probe -x /lib/modules/$(uname -r)/build/vmlinux 'SyS_write%return $retval' --force

4、启用探针并记录:sudo perf record -e probe:SyS_write -e probe:SyS_write__return -a -- sleep 5

四、使用perf report交互式查看延迟热点

perf report可将perf.data中采样的延迟事件按调用或系统调用名聚合,识别高频高延迟syscall及其上下文。支持TUI界面实时过滤与钻取,适用于快速定位问题模块。

1、运行sudo perf report -n --sort comm,dso,symbol --no-children

2、在交互界面中按/键输入"sys_"搜索所有系统调用相关条目

3、选中某syscall行后按Enter展开其调用栈,观察延迟占比最高的一级函数

4、按s键保存当前视图至report_syscall.txt

五、使用perf stat统计全局系统调用延迟均值

perf stat提供轻量级聚合统计,不记录单次事件,但能快速获得指定时间段内所有系统调用的平均延迟、最大延迟及总次数。适合日常巡检与基线比对。

1、执行sudo perf stat -e 'syscalls:sys_enter_*' -e 'syscalls:sys_exit_*' -I 1000 -a -- sleep 30

2、观察每秒输出块中的syscalls:sys_enter_* 和 syscalls:sys_exit_* 的事件计数差值

3、结合--log选项将结果重定向至日志:sudo perf stat -e 'syscalls:sys_enter_*' -e 'syscalls:sys_exit_*' --log-fd 1 -- sleep 10 2>&1 | grep "syscalls"

相关专题

更多
sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

387

2023.09.04

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

393

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

572

2023.08.10

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1352

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

704

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

294

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

776

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

573

2023.07.06

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

6

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.6万人学习

Git 教程
Git 教程

共21课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号