10.2. 使用 ltrace
要在您要分析的程序中运行 ltrace
工具:
$ scl enable devtoolset-11 'ltrace program argument...'
使用您要 分析的程序的名称替换 program,使用您要提供的任何命令行选项和参数替换 program。或者,您可以使用 -p
命令行选项以及进程 ID 在已经运行的进程中运行实用程序:
$ scl enable devtoolset-11 'ltrace -p process_id'
请注意,您可以使用 scl
程序执行任何命令,从而导致使用 Red Hat Developer Toolset 二进制文件运行它,而不是 Red Hat Enterprise Linux 系统等同的 Red Hat Enterprise Linux 系统。这可让您以 Red Hat Developer Toolset ltrace
作为默认值运行 shell 会话:
$ scl enable devtoolset-11 'bash'
在任意时间点验证您使用的 ltrace
版本:
$ which ltrace
Red Hat Developer Toolset 的 ltrace
可执行文件路径以 /opt
开头。另外,您可以使用以下命令确认与 Red Hat Developer Toolset ltrace
的版本号匹配:
$ ltrace -V
10.2.1. 将输出重定向到文件
默认情况下,l
trace 会打印每个系统调用的名称,其参数和返回值到标准错误输出。要将这个输出重定向到文件,请使用 -o
命令行选项以及文件名:
$ scl enable devtoolset-11 'ltrace -o file_name program argument...'
使用文件名替换 file_name。
例 10.1. 将输出重定向到文件
考虑从 例 8.1 “使用调试信息编译 C 程序” 的 fibonacci
文件的稍加修改版本。这个可执行文件显示 Fibonacci 序列,并可以选择指定要列出此序列的多少个成员。在此文件上运行 ltrace
实用程序并将 trace 输出重定向到 fibonacci.log
:
$ scl enable devtoolset-11 'ltrace -o fibonacci.log ./fibonacci 20'
1 1 2 3 5 8 13 21 34 55 89 144 233 377 610 987 1597 2584 4181 6765
这会在当前工作目录中创建一个名为 fibonacci.log
的纯文本文件。