由于最近的一些业务在linux系统上高并发的情况下发生了很多问题,最终都是使用strace跟踪找到了问题所在,便整理了一份strace的使用方法和详解,也拿出来给大家分享一下

功能说明:

strace 命令是一种强大的工具, 能够显示任何由用户空间程式发出的系统调用. strace 显示这些调用的参数并返回符号形式的值. strace 从内核接收信息, 而且无需以任何特别的方式来构建内核. strace 的每一行输出包括系统调用名称, 然后是参数和返回值.
下面记录几个常用option:
-f -F选项告诉strace同时跟踪fork和vfork出来的进程
-o xxx.txt 输出到某个文档.
-e execve 只记录 execve 这类系统调用.

实例说明:

配置php将其开户一个进程,方便每次都能跟踪到数据,如开户多个将刷新多次才可能分配到你监听的进程上
用以下php来做一个示例保存为test2.php(因facebook在国空被gfw,所以请求肯定会超时,特拿来做试验)
<?php
$a = exec(“curl -I www.facebook.com”,$out,$status);
print_r($a);
print_r($out);
print_r($status);
?>

使用curl请求地址或是通过ie请求
Curl –I http://100.100.100.6/test2.php
在服务端监听其端口(可使用ps –auxf|grep php-fpm)来确定其进程号
Strace –p 32448(也可使用strace –T –p 32448看每个执行的时间)

如果执行请求后,可看在上图看到php当执行到
$a = exec(“curl -I www.facebook.com”,$out,$status);
时开始等待返回,25秒左右后才返回结果
另一种测试方法,也可以直接用php去执行跟踪
Strace /usr/bin/php test2.php

以上图可看到,程序也是在执行
exec(“curl -I www.facebook.com”,$out,$status);的时候开始等待返回,耗费21秒时间

Strace还可以跟踪服务启动过程,帮我们解决一些服务在启动过程中遇到的问题,以下以nginx配置错误为例
以下是不存在/log根目录的、我们来跟踪启动看是什么效果

Strace /usr/local/nginx/sbin/nginx
以下是其返回结果,也可以看到提示目录有误

Strace在跟踪时返回0则程序执行正常,如返回其它数字则会继续查找,直到所有默认文件或是设置都不存在时才会报错

详细参数说明 :

-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 column 设置返回值的输出位置.默认 为40.
-e expr 指定一个表达式,用来控制如何跟踪.格式如下:
[qualifier=][!]value1[,value2]…
qualifier只能是 trace,abbrev,verbose,raw,signal,read,write其中之一.value是用来限定的符号或数字.默认的 qualifier是 trace.感叹号是否定符号.例如-eopen等价于 -e trace=open,表示只跟踪open调用.而-etrace!=open表示跟踪除了open以外的其它调用.有两个特殊的符号 all 和 none. 注意有些shell使用!来执行历史记录里的命令,所以要使用\.
-e trace=set 只跟踪指定的系统调用.例如:-e trace=open,close,rean,write表示只跟踪这四个系统调用.默认的为set=all.
-e trace=file 只跟踪有关文件操作的系统调用.
-e trace=process 只跟踪有关进程控制的系统调用.
-e trace=network 跟踪与网络有关的所有系统调用.
-e strace=signal 跟踪所有与系统信号有关的系统调用.
-e trace=ipc 跟踪所有与进程通讯有关的系统调用.
-e abbrev=set 设定strace输出的系统调用的结果集.-v 等与 abbrev=none.默认为abbrev=all.
-e raw=set 将指定的系统调用的参数以十六进制显示.
-e signal=set 指定跟踪的系统信号.默认为all.如 signal=!SIGIO(或者signal=!io),表示不跟踪SIGIO信号.
-e read=set 输出从指定文件中读出的数据.例如-e read=3,5
-e write=set 输出写入到指定文件中的数据.
-o filename 将strace的输出写入文件filename
-p pid 跟踪指定的进程pid.
-s strsize 指定输出的字符串的最大长度.默认为32.文件名一直全部输出.
-u username 以username 的UID和GID执行被跟踪的命令.

苦咖啡原创
转载请注明出处:http://www.kukafei520.net



分享到: 更多

这篇日志的 QR 二维码为:

十一月 30th, 2011

Posted In: 未分类

无觅相关文章插件,快速提升流量