Linux的strace工具使用

strace 是一个在 Linux 系统中用于跟踪进程执行时的系统调用和接收的信号的工具。它可以帮助开发者诊断程序运行时的问题,比如程序崩溃、性能问题等。下面是 strace 的一些常用命令行选项和它们的解释:

  1. 基本用法 :

    复制代码
    strace [选项] 命令 [参数...]
  2. 常用选项 :

    • -c: 统计每个系统调用的执行时间、调用次数和错误次数。
    • -f: 跟踪由 fork() 调用产生的子进程。
    • -p: 指定要跟踪的进程 ID。
    • -t: 在输出的每一行前加上时间戳。
    • -v: 输出详细的系统调用信息。
    • -o: 将输出的信息保存到文件中。
    • -e: 指定要跟踪的系统调用或者信号。
  3. 示例 :

    • 跟踪 cat 命令的系统调用:

      复制代码
      strace -c cat /dev/null
    • 跟踪进程 ID 为 1234 的进程的所有系统调用:

      复制代码
      strace -p 1234
    • 跟踪进程 ID 为 1234 的进程,并将输出保存到文件中:

      复制代码
      strace -p 1234 -o output.txt
    • 跟踪 open 系统调用和 close 系统调用:

      复制代码
      strace -e open,close cat /dev/null
  4. 高级用法 :

    • 使用 -a 选项来指定列的对齐方式。
    • 使用 -s 选项来指定字符串的长度。
    • 使用 -u 选项来指定用户名。
    • 使用 -e signal 来跟踪特定的信号。
  5. 信号跟踪 :
    当跟踪信号时,strace 会在信号处理函数前加上 ---,并在信号处理函数调用结束后加上信号的名称和错误码。

  6. 错误分析 :
    当系统调用出错时,strace 会显示错误码和错误描述。例如,ENOENT 表示文件或目录不存在。

  7. 性能分析 :
    使用 -T 选项来跟踪每个系统调用的花费时间。
    strace 是一个强大的工具,对于理解程序如何与操作系统交互非常有帮助。通过结合使用不同的选项,你可以获得关于程序运行的详细信息,从而帮助诊断和解决问题。

相关推荐
好好学习啊天天向上3 小时前
C盘容量不够,python , pip,安装包的位置
linux·python·pip
二十雨辰3 小时前
[python]-循环语句
服务器·python
li_wen013 小时前
文件系统(八):Linux JFFS2文件系统工作原理、优势与局限
大数据·linux·数据库·文件系统·jffs2
wypywyp3 小时前
2.虚拟机一直显示黑屏,无法打开,可能是分配的硬盘空间不够
linux·运维·服务器
SongYuLong的博客4 小时前
TL-WR710N-V2.1 硬改刷机OpenWRT源码编译固件
linux·物联网·网络协议
m0_737302584 小时前
碳足迹精准计量,华为FusionSolar助力云服务器绿色运维
服务器
AlfredZhao4 小时前
Docker 快速入门:手把手教你打包 Python 应用
linux·docker·podman
HIT_Weston5 小时前
107、【Ubuntu】【Hugo】搭建私人博客:模糊搜索 Fuse.js(三)
linux·javascript·ubuntu
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.5 小时前
Haproxy会话保持:基于Cookie优化
运维·负载均衡
艾莉丝努力练剑5 小时前
【优选算法必刷100题】第007~008题(双指针算法):三数之和、四数之和问题求解
linux·算法·双指针·优选算法