Linux strace检查程序的系统调用及时间

strace是一个强大的工具,用于跟踪Linux进程的系统调用和信号处理。它可以显示进程执行的每个系统调用的详细信息,包括参数、返回值和执行时间。strace可用于调试、性能分析和理解程序行为。通过使用不同参数,如`-c`进行统计,`-f`跟踪子进程,`-T`显示时间等,用户可以定制跟踪行为。例如,`strace -o output.txt -T -tt -e trace=all -p28979`会跟踪PID为28979的进程并记录结果。此外,strace在解决库依赖问题和分析特定系统调用(如`execve`)方面也非常有用。
摘要由CSDN通过智能技术生成

简介

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

输出参数含义

root@ubuntu:/usr# strace cat /dev/null

execve("/bin/cat", ["cat","/dev/null"], [/* 22 vars */]) =0

brk(0)                                  =0xab1000

access("/etc/ld.so.nohwcap", F_OK)      = -1ENOENT (No such file or directory)

mmap(NULL,8192, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1,0) =0x7f29379a7000

access("/etc/ld.so.preload", R_OK)      = -1ENOENT (No such file or directory)

...

brk(0) =0xab1000

brk(0xad2000) =0xad2000

fstat(1, {st_mode=S_IFCHR|0620, st_rdev=makedev(136,0), ...}) =0

open("/dev/null", O_RDONLY) =3

fstat(3, {st_mode=S_IFCHR|0666, st_rdev=makedev(1,3), ...}) =0

read(3,"",32768) =0

close(3) =0

close(1) =0

close(2) =0

exit_group(0) = ?

每一行都是一条系统调用,等号左边是系统调用的函数名及其参数,右边是该调用的返回值。

strace 显示这些调用的参数并返回符号形式的值。strace 从内核接收信息,而且不需要以任何特殊的方式来构建内核。

strace参数

-c 统计每一系统调用的所执行的时间,次数和出错的次数等.

-d 输出strace关于标准错误的调试信息.

-f 跟踪由fork调用所产生的子进程.

-ff 如果提供-o filename,则所有进程的跟踪结果输出到相应的filename.pid中,pid是各进程的进程号.

-F 尝试跟踪vfork调用.在-f时,vfork不被跟踪.

-h 输出简要的帮助信息.

-i 输出系统调用的入口指针.

-q 禁止输出关于脱离的消息.

-r 打印出相对时间关于,,每一个系统调用.

-t 在输出中的每一行前加上时间信息.

-tt 在输出中的每一行前加上时间信息,微秒级.

-ttt 微秒级输出,以秒了表示时间.

-T 显示每一调用所耗的时间.

-v 输出所有的系统调用.一些调用关于环境变量,状态,输入输出等调用由于使用频繁,默认不输出.

-V 输出strace的版本信息.

-x 以十六进制形式输出非标准字符串

-xx 所有字符串以十六进制形式输出.

-a colu

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值