简介
很多时候我们希望可以看到一个进程调用了哪些API以及其调用顺序,例如我们要参考某个程序的实现,但我们又无法获得该程序的源代码时,使用系统调用跟踪命令不失为一个好办法。另外,在一些无法调试的环境上检查问题时,我们也可以用该命令来查看程序是否按预期执行。strace、ltrace、dtruss都是同一类型的命令,strace是linux系统上的,ltrace是debian类系统上的,而dtruss是mac系统上的。
strace常用来跟踪进程执行时的系统调用和所接收的信号。 在Linux世界,进程不能直接访问硬件设备,当进程需要访问硬件设备(比如读取磁盘文件,接收网络数据等等)时,必须由用户态模式切换至内核态模式,通 过系统调用访问硬件设备。strace可以跟踪到一个进程产生的系统调用,包括参数,返回值,执行消耗的时间。
命令
strace —— Trace system calls and signals。 跟踪进程的系统调用或信号产生的情况。
ltrace —— A library call tracer。 跟踪进程调用库函数的情况。
strace: (该方法无法发现用户写出的程序或共享库中发生的错误)
strace -o output.txt -T -tt -e trace=all -p 28979
( 跟踪28979进程的所有系统调用(-e trace=all),并统计系统调用的花费时间,
以及开始时间(以时分秒格式显示),最后将记录结果存在output.txt文件里面)
1.使用strace启动进程(假设程序名st1)
$ strace st1 (//从后往前看st