首页
学习
活动
专区
工具
TVP
发布

Linux 命令(137)—— strace 命令

1.命令简介 strace 命令是一个集诊断、调试、统计于一体的工具,我们可以使用 strace 对程序的系统调用和信号传递的跟踪结果来对程序进行分析,以达到解决问题或者是了解程序工作过程的目的。...strace -o strace.out ./a.out 输入 4 然后回车生成 strace 的输出文件 strace.out,其内容如下: execve("./a.out", ["....#开启跟踪 strace -e trace=signal -o strace.out ./a.out #查找进程 ....strace 不光能追踪系统调用,通过使用参数 -c,它还能将进程所有的系统调用做一个统计分析给你,下面来看看 strace 对系统调用的统计。 strace -c ....具体用法如下: strace -p PID ---- 参考文献 [1] strace(1) manual [2] Linux 命令大全.strace [3] 马昌伟.strace命令详解

7.1K31
您找到你想要的搜索结果了吗?
是的
没有找到

pstack 与 strace

strace   strace是可以记录程序系统调用的一个工具,它可以记录该程序系统调用的各个延时情况。 -c 统计每一系统调用的所执行的时间,次数和出错的次数等....-d 输出strace关于标准错误的调试信息. -f 跟踪由fork调用所产生的子进程....-V 输出strace的版本信息. -x 以十六进制形式输出非标准字符串 -xx 所有字符串以十六进制形式输出. -a column 设置返回值的输出位置.默认 为40....-e strace=signal 跟踪所有与系统信号有关的 系统调用 -e trace=ipc 跟踪所有与进程通讯有关的系统调用 -e abbrev=set 设定 strace输出的系统调用的结果集....-u username 以username 的UID和GID执行被跟踪的命令 strace 实用选项 strace -T -r -c -p pid 打印出该pid进程的系统调用耗时 pstack   它是一个打印进程的所有线程栈的一个工具

98720

strace命令解析

strace常用于跟踪和分析进程执行时中系统调用和耗时以及占用cpu的比例,常用的格式如下: 1.sudo /usr/bin/strace -Ttt -p pid 2>pid.log 跟进pid进程,显示每个系统调用耗时...下面列出man手册中strace的详细参数。 调用: strace [ -dffhiqrtttTvxx ] [ -acolumn ] [ -eexpr ] ......strace的每一行输出包括系统调用名称,然后是参数和返回值.这个例子: strace cat /dev/null 他的输出会有: open(/"/dev/null/",O_RDONLY) = 3...-d 输出strace关于标准错误的调试信息. -f 跟踪由fork调用所产生的子进程....-e strace=signal 跟踪所有与系统信号有关的系统调用 -e trace=ipc 跟踪所有与进程通讯有关的系统调用 -e abbrev=set 设定strace输出的系统调用的结果集

1.4K10

Strace命令手册

strace简介 strace常用来跟踪进程执行时的系统调用和所接收的信号。...在Linux世界,进程不能直接访问硬件设备,当进程需要访问硬件设备(比如读取磁盘文件,接收网络数据等等)时,必须由用户态模式切换至内核态模式,通 过系统调用访问硬件设备。...strace可以跟踪到一个进程产生的系统调用,包括参数,返回值,执行消耗的时间。 strace参数 -c 统计每一系统调用的所执行的时间,次数和出错的次数等....-e strace=signal 跟踪所有与系统信号有关的 系统调用 -e trace=ipc 跟踪所有与进程通讯有关的系统调用 -e abbrev=set 设定 strace输出的系统调用的结果集...(strace -a open php) 3、跟踪进程(strace -p 1008) 4、系统调用概要,执行时间,错误等信息(strace -c php) 案例: 1、保存输出结构strace

1.6K80

strace详解及实战

命令,就很牛了,而现在大家基本都知道 strace 了,如果你遇到性能问题求助别人,十有八九会建议你用 strace 挂上去看看,不过当你挂上去了,看着满屏翻滚的字符,却十有八九看不出个所以然。...Linux 操作系统有很多用来跟踪程序行为的工具,内核态的函数调用跟踪用「strace」,用户态的函数调用跟踪用「ltrace」,所以这里我们应该用「strace」: shell> strace -p... 不过如果直接用 strace 跟踪某个进程的话,那么等待你的往往是满屏翻滚的字符,想从这里看出问题的症结并不是一件容易的事情,好在 strace 可以按操作汇总时间: shell> strace...strace 跟踪一个进程,输出结果很少,是不是说明进程很空闲?...我常用的: 用来观察性能、error log: strace -T -vvvv -d -Ff -s 128 -o strace.log -p PID 查找瓶颈调用: strace -v -T -d

1.5K30

linux下 debug 工具 strace 应用之【查找命令依赖库文件】

Stracelinux系统中一个用来跟踪系统调用的简易工具,它最简单的用途就是跟踪一个程序整个生命周期里所有的系统调用,并把调用参数和返回值以文本的方式输出 当然它还可以做更多的事情: strace...strace 可以记录系统调用的次数,时间,成功和失败的次数。 strace 可以跟踪发给进程的信号。...strace 可以通过pid附加到任何正在运行的进程上 问题背景: centos下执行rpm命令时提示缺失 libplds4.so 的库文件,这导致系统命令执行失败 root@BJ-CentOS7 ~...通过 strace 命令追踪 rpm 命令执行过程,发现这里调用的文件绝对路径是 /lib64/libplds4.so ,原因是 /lib64 目录是 /usr/lib64 软链过来的,find 命令默认不查找软链目录...使用 strace 命令追踪系统命令执行调用的系统文件路径(参数 -e open 用于观察目前进程正引用哪些文件) root@BJ-CentOS7 ~ # strace -e open rpm -qa

2K20

通过Strace定位故障原因

闲言碎语不要讲,轮到Strace出场了,统计一下各个系统调用的耗时情况: shell> strace -c -p $(pgrep -n php-cgi) % time seconds usecs...100.00 0.077145 13066 118 total 看上去「brk」非常可疑,它竟然耗费了三成的时间,保险起见,单独确认一下: shell> strace...0x1f98000 brk(0x1fd8000) = 0x1fd8000 brk(0x2018000) = 0x2018000 说明:在Strace...shell> strace -T -p $(pgrep -n php-cgi) 2>&1 | grep -B 10 brk stat("/path/to/script.php", {...}) = 0...直接把它们都禁用了,看看服务器是否能缓过来,或许大家觉得这太鲁蒙了,但是特殊情况必须做出特殊的决定,不能像个娘们儿似的优柔寡断,没过多久,服务器负载恢复正常,接着再统计一下系统调用的耗时: shell> strace

50320

系统调用跟踪分析神器--strace

前言 最近遇到两起应用系统层面性能问题的案例,同事在排查问题的时候使用了strace这款神器,给自己在以后解决系统性能问题时提供了思路,本文学习了解系统分析工具---strace。...strace 是什么?...strace命令是一个集诊断、调试、统计与一体的工具,我们可以利用strace来跟踪debug应用程序的系统调用和信号传递过程,以便我们对应用运行机制进行分析,从而解决应用程序遇到的问题。...strace 使用姿势 strace的使用相当简单,就是执行一个指定的命令比如 strace -T -tt -s 100 -o /tmp/strace.log CMD 在指定的CMD命令结束之后它也就退出...或者 strace -T -tt -s 100 -o /tmp/strace.log -p PID 对于指定进程号的跟踪,需要Crtl +C 结束调用。

2.6K20

强大的strace命令用法详解

strace是什么? 按照strace官网的描述, strace是一个可用于诊断、调试和教学的Linux用户空间跟踪器。...在Linux系统上,应用代码通过glibc库封装的函数,间接使用系统调用。 Linux内核目前有300多个系统调用,详细的列表可以通过syscalls手册页查看。...不过,对于运维的问题定位来说,知道strace这个工具,会查系统调用手册,就差不多够了。 想要深入了解的同学,建议阅读《Linux系统编程》, 《Unix环境高级编程》等书籍。...3、 性能分析 假如有个需求,统计Linux 4.5.4 版本内核中的代码行数(包含汇编和C代码)。这里提供两个Shell脚本实现: poor_script.sh: !.../bin/bash find linux-4.5.4 -type f  ( -iname ‘.c’ -o -iname ‘.h’ -o -iname ‘*.S’ ) -print0 \ | wc -

1.2K30

Strace——隐藏的超能力

Linux 管理员和工程师很快发现需要补充实用程序。值得庆幸的是,他们并没有等太久。 StraceLinux 之后不久推出,旨在解决其中的许多问题。...正如官方网站所述,正式称为 Linux 系统调用调用程序,“StraceLinux 的诊断、调试和指导用户空间实用程序”。您可以使用 Strace 来监督和操作进程如何与 Linux 内核交互。...Linux 内核的“ptrace”功能最终使 Strace 发挥其魔力。创建“ptrace”本身是为了促进系统调用跟踪和断点调试。 Strace 至今仍保持开源状态。...strace 语法 StraceLinux CLI 在每个 Strace 命令中利用多个运算符。这些选项有不同的用途,因此您可以使用它们来执行非常具体的操作。...Strace 并非在所有情况下都是完美的。然而,它的灵活性吸引了经验丰富的管理员。总体而言,Strace 有助于构建 Linux 的开源基础,提供您可能无法获得的见解。

16010
领券