0

0

如何追踪Linux系统调用 strace调试命令详解

P粉602998670

P粉602998670

发布时间:2025-07-31 12:58:01

|

708人浏览过

|

来源于php中文网

原创

strace 是 linux 下用于追踪系统调用的调试工具,其基本用法为 strace command,可显示程序运行过程中与内核交互的所有系统调用。1. 使用 -e trace= 可指定追踪特定调用,如 strace -e trace=open,close,read ls -l;2. 加 -t 选项可查看调用耗时,用于性能分析;3. 使用 -f 可追踪子进程;4. -o output.txt 可将输出保存至文件;5. -e trace=network 可追踪网络相关调用;6. -e trace=signal 可追踪信号交互;7. -c 可统计调用次数和耗时汇总;8. 权限不足可能导致 eperm 或 eaccess 错误;9. strace 会影响程序性能,应避免在生产环境使用;10. 使用 -p 可附加到正在运行的进程进行追踪,但需 root 权限。

如何追踪Linux系统调用 strace调试命令详解

追踪Linux系统调用,简单来说,就是想知道程序在运行过程中都向操作系统发出了哪些请求。strace 命令就是干这个的利器,它像一个窃听器,默默记录程序和内核之间的对话,帮助我们诊断问题、理解程序行为。

如何追踪Linux系统调用 strace调试命令详解

strace 调试命令详解:

strace 的基本用法很简单:strace command。它会执行 command,并把 command 执行过程中所有的系统调用都打印出来。

如何追踪Linux系统调用 strace调试命令详解

例如,想看看 ls -l 命令都做了什么,就执行 strace ls -l。 屏幕上会刷出一大堆信息,包括打开文件、读取目录、分配内存等等。

但直接这样用,信息量太大,容易迷失。我们需要一些选项来过滤和聚焦。

如何追踪Linux系统调用 strace调试命令详解

如何只追踪特定的系统调用?

strace -e trace=open,close,read ls -l

这个命令只追踪 opencloseread 这三个系统调用。-e trace= 选项可以指定要追踪的系统调用列表,用逗号分隔。这招在排查文件读写相关问题时特别有用。

如何查看系统调用的耗时?

strace -T ls -l

-T 选项会显示每个系统调用花费的时间。这对于性能分析非常重要,可以找出哪些系统调用是瓶颈。例如,如果发现某个 read 系统调用特别慢,那可能就是磁盘IO有问题。

如何追踪子进程?

strace -f ls -l

-f 选项会追踪所有由 ls -l 启动的子进程。有些程序会fork出多个进程来并行处理任务,这时就需要 -f 来追踪整个过程。

如何将输出保存到文件?

strace -o output.txt ls -l

-o output.txt 会将 strace 的输出保存到 output.txt 文件中。这在需要仔细分析结果时非常方便,可以避免屏幕输出的干扰。

如何追踪网络相关的系统调用?

strace -e trace=network nc -l 12345

短影AI
短影AI

长视频一键生成精彩短视频

下载

network 是一个预定义的集合,包含了所有网络相关的系统调用,例如 socketbindlistenacceptconnectsendrecv 等。这个命令可以用来调试网络程序,例如查看端口是否被正确监听,数据是否被正确发送和接收。

如何追踪信号?

strace -e trace=signal kill -SIGTERM

-e trace=signal 会追踪信号的发送和接收。可以用来调试进程间的通信问题,例如查看进程是否收到了预期的信号。 是进程的ID。

如何只显示系统调用的名称,不显示参数?

strace -c ls -l

-c 选项会统计每个系统调用的调用次数和耗时,并生成一个汇总报告。这对于性能分析非常有用,可以快速找出哪些系统调用是性能瓶颈。但它不会显示具体的参数,如果需要参数,就不能用这个选项。

为什么 strace 有时候会显示 EPERMEACCESS

EPERM 表示 "Operation not permitted",通常是因为权限不足。例如,尝试打开一个没有读权限的文件,或者尝试向一个没有写权限的文件写入数据。

EACCESS 表示 "Permission denied",也表示权限不足,但通常是因为文件路径中的某个目录没有执行权限。例如,尝试打开 /home/user/private/file.txt,但 user 用户对 private 目录没有执行权限。

遇到这些错误,首先要检查用户的权限是否足够。如果权限看起来没问题,那可能就是 SELinux 或 AppArmor 等安全机制在作祟。这些安全机制会限制程序的访问权限,即使用户有权限,程序也可能无法访问某些资源。

strace 会影响程序的性能吗?

会。strace 本身就是一个调试工具,它会拦截程序的系统调用,并进行记录。这个过程会增加程序的开销,导致程序运行变慢。

因此,strace 不应该在生产环境中使用,除非是为了诊断非常紧急的问题。在调试环境中使用 strace 时,也应该尽量减少追踪的系统调用数量,以减少对程序性能的影响。

如何在不停止程序的情况下使用 strace

strace -p

-p 选项可以附加到一个正在运行的进程上,并开始追踪它的系统调用。这对于调试已经运行的程序非常有用,例如服务器程序。 是进程的ID。

需要注意的是,使用 -p 选项需要 root 权限,因为你需要访问其他进程的内存空间。

相关专题

更多
堆和栈的区别
堆和栈的区别

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

392

2023.07.18

堆和栈区别
堆和栈区别

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

572

2023.08.10

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

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

1349

2023.06.21

如何安装LINUX
如何安装LINUX

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

703

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

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

546

2023.07.20

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

52

2026.01.19

热门下载

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

精品课程

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

共48课时 | 7.5万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

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

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