strace调试工具

strace工具用于跟踪进程执行时的系统调用和所接收的信号,包括参数、返回值、执行时间。在Linux中,用户程序要访问系统设备,必须由用户态切换到内核态,这是通过系统调用发起并完成的。

strace常用参数:

  • -c  统计每种系统调用执行的时间、调用次数、出错次数,程序退出时给出报告
  • -p pid  跟踪指定的进程,可以使用多个-p同时跟踪多个进程
  • -o filename  strace默认输出到stdout,-o可以将输出写入到指定的文件
  • -f  跟踪由fork产生的子进程的系统调用
  • -ff  常与-o选项一起使用,不同进程(子进程)产生的系统调用输出到各个filename.pid文件中
  • -F  尝试跟踪vfork子进程系统调用,注意:与-f同时使用时, vfork不被跟踪
  • -e expr  输出过滤表达式,可以过滤掉不想输出的strace结果
  • -e trace=set  指定跟踪set中的系统调用
  • -e trace=network  跟踪与网络有关的所有系统调用
  • -e strace=signal  跟踪所有与系统信号有关的系统调用
  • -e trace=ipc  跟踪所有与进程通讯有关的系统调用
  • -e signal=set  指定跟踪set中的信号
  • -e read=set  输出从指定文件中读出的数据,例如-e read=3,5
  • -e write=set  输出写入到指定文件中的数据,例如-e write=1
  • -r  打印每一个系统调用的相对时间
  • -t  在输出中的每一行前加上时间信息
  • -tt  在输出中的每一行前加上时间信息,时间精确到微秒级
  • -ttt  在输出中的每一行前加上时间信息,输出为相对时间
  • -s  指定每一行输出字符串的长度(默认为32)

strace使用举例:

strace -t ls  #跟踪ls可执行程序,每行输出结果前打印执行的时间

strace -o output.txt -f -T -tt -e trace=all -p 8979 #跟踪进程8979及其子进程的所有系统调用

你可能感兴趣的:(工具,调试,strace)