Linux利器 strace

strace常用来跟踪进程执行时的系统调用和所接收的信号。 在Linux世界,进程不能直接访问硬件设备,当进程需要访问硬件设备(比如读取磁盘文件,接收网络数据等等)时,必须由用户态模式切换至内核态模式,通过系统调用访问硬件设备。strace可以跟踪到一个进程产生的系统调用,包括参数,返回值,执行消耗的时间。

strace使用参数

-p 跟踪指定的进程
-f跟踪由fork子进程系统调用
-F尝试跟踪vfork子进程系统调吸入,与-f同时出现时, vfork不被跟踪
-o filename 默认strace将结果输出到stdout。通过-o可以将输出写入到filename文件中
-ff常与-o选项一起使用,不同进程(子进程)产生的系统调用输出到filename.PID文件
-r打印每一个系统调用的相对时间
-t在输出中的每一行前加上时间信息。 -tt 时间确定到微秒级。还可以使用-ttt打印相对时间
-v输出所有系统调用。默认情况下,一些频繁调用的系统调用不会输出
-s指定每一行输出字符串的长度,默认是32。文件名一直全部输出
-c统计每种系统调用所执行的时间,调用次数,出错次数。
-eexpr输出过滤器,通过表达式,可以过滤出掉你不想要输出

http://www.vimer.cn/2009/11/strace%E5%91%BD%E4%BB%A4%E7%94%A8%E6%B3%95%E8%AF%A6%E8%A7%A3.html

http://www.thegeekstuff.com/2011/11/strace-examples/ 推荐阅读

04-22 23:41