资讯专栏INFORMATION COLUMN

strace & ltrace & phpstrace

huayeluoliuhen / 2293人阅读

摘要:是环境下的一款程序调试工具,用来监察一个应用程序所使用的系统调用及它所接收的系统信息。追踪程序运行时的整个生命周期,输出每一个系统调用的名字,参数,返回值和执行消耗的时间等。设置打印的字符串最大长度。使用某个用户或组来运行命令。

strace

strace是Linux环境下的一款程序调试工具,用来监察一个应用程序所使用的系统调用及它所接收的系统信息。追踪程序运行时的整个生命周期,输出每一个系统调用的名字,参数,返回值和执行消耗的时间等。

常用参数:

-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 统计每种系统调用所执行的时间,调用次数,出错次数。
-e expr 输出过滤器,通过表达式,可以过滤出掉你不想要输出

追踪多个进程方法

当有多个子进程的情况下,比如php-fpm、nginx等,用strace追踪显得很不方便。可以使用下面的方法来追踪所有的子进程。

</>复制代码

  1. # vim /root/.bashrc //添加以下内容
  2. function straceall {
  3. strace $(pidof "${1}" | sed "s/([0-9]*)/-p 1/g")
  4. }
  5. # source /root/.bashrc
  6. # traceall php-fpm //监控phpfpm
  7. OR
  8. # strace -tt -T $(pidof "php-fpm: pool www" | sed "s/([0-9]*)/-p 1/g")
追踪web服务

</>复制代码

  1. # strace -f -F -s 1024 -o nginx-strace /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
  2. # strace -f -F -o php-fpm-strace /usr/local/php/sbin/php-fpm -y /usr/local/php/etc/php-fpm.conf
追踪mysql

</>复制代码

  1. # strace -f -F -ff -o mysqld-strace -s 1024 -p mysql_pid
  2. # find ./ -name "mysqld-strace*" -type f -print |xargs grep -n "SELECT.*FROM"
查看程序做了什么

</>复制代码

  1. #!/bin/bash
  2. # This script is from http://poormansprofiler.org/
  3. nsamples=1
  4. sleeptime=0
  5. pid=$(pidof $1)
  6. for x in $(seq 1 $nsamples)
  7. do
  8. gdb -ex "set pagination 0" -ex "thread apply all bt" -batch -p $pid
  9. sleep $sleeptime
  10. done |
  11. awk "
  12. BEGIN { s = ""; }
  13. /^Thread/ { print s; s = ""; }
  14. /^#/ { if (s != "" ) { s = s "," $4} else { s = $4 } }
  15. END { print s }" |
  16. sort | uniq -c | sort -r -n -k 1,1
ltrace

-a 对齐具体某个列的返回值
-c 计算时间和调用,并在程序退出时打印摘要
-C 解码低级别名称(内核级)为用户级名称
-d 打印调试信息
-e 改变跟踪的事件
-f 跟踪子进
-h 打印帮助信息
-i 打印指令指针,当库调用时。
-l 只打印某个库中的调用。
-L 不打印库调用。
-n, --indent=NR 对每个调用级别嵌套以NR个空格进行缩进输出。
-o, --output=file 把输出定向到文件。
-p PID 附着在值为PID的进程号上进行ltrace。
-r 打印相对时间戳。
-s STRLEN 设置打印的字符串最大长度。
-S 显示系统调用。
-t, -tt, -ttt 打印绝对时间戳。
-T 输出每个调用过程的时间开销。
-u USERNAME 使用某个用户id或组ID来运行命令。
-V, --version 打印版本信息,然后退出。
-x NAME treat the global NAME like a library subroutine.

phpstrace

phpstrace追踪php进程

</>复制代码

  1. Usage: ./php-strace [ options ]
  2. -h|--help show this help
  3. -l|--lines output the last N lines of a stacktrace. Default: 100
  4. --process-name name of running php processes. Default: autodetect
  5. --live search while running for new upcoming pid"s

</>复制代码

  1. 使用truss/strace/ltrace跟踪进程

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/31961.html

相关文章

发表评论

0条评论

最新活动
阅读需要支付1元查看
<