linux命令之调试工具strace的深入分析


Posted in PHP onJune 03, 2013

参考
1《linux的strace命令(详解).txt》 新浪电子书可下载
2man strace
一个基本上通用的 完整的用法:
strace -o output.txt -T -tt -e trace=all -p 28979
上面的含义是 跟踪28979进程的所有系统调用(-e trace=all),并统计系统调用的花费时间,以及开始时间(并以可视化的时分秒格式显示),最后将记录结果存在output.txt文件里面。
必须记住的几个用法
1)strace -p pid  可以跟踪某个后台进程
2)strace -o filename 把跟踪结果输出到文件
3)strace -T 记录每个系统调用花费的时间,可以看看哪个系统调用时间长
4)strace -t (或者 -tt)记录每个系统调用发生是的时间(时分秒的格式)
5)strace -s 1024 显示系统调用参数时,对于字符串显示的长度, 默认是32,如果字符串参数很长,很多信息显示不出来。
6)strace -e trace=nanosleep 只记录相关的系统调用信息。
    -e trace=network // 只记录和网络api相关的系统调用
    -e trace=file // 只记录涉及到文件名的系统调用
    -e trace=desc // 只记录涉及到文件句柄的系统调用
还有其他的包括process,ipc,signal等。
一个经典的,通过strace查看一个进程所有相关打开文件的排查过程,参考《linux的strace命令(详解).txt》 新浪电子书可下载
如果开发程序没有一个强大的工具相伴,那么开发效率会非常低,甚至遇到问题无从下手. 现在开始学习linux下的强大的调试工具strace,并记录于此.
strace
1)类似于windows下的processexp.exe
   可以监控系统调用
2)类似于windows下的depand工具
   可以检查程序的依赖库. 比linux下的ldd更强大.
   参考:strace命令用法 
   点击下载
   案例:
strace帮助我解决不知日志文件被打印到哪的问题.
   用strace跟踪server
   /usr/bin/strace -p pid -o out.file
   然后执行client端,然后结束strace,查看out.file 搜索write,open的系统调用

PHP 相关文章推荐
PHP 远程文件管理,可以给表格排序,遍历目录,时间排序
Aug 07 PHP
php 日期和时间的处理-郑阿奇(续)
Jul 04 PHP
php使用exec shell命令注入的方法讲解
Nov 12 PHP
php指定函数参数默认值示例代码
Dec 04 PHP
windows下PHP_intl.dll正确配置方法(apache2.2+php5.3.5)
Jan 14 PHP
分享一个超好用的php header下载函数
Jan 31 PHP
PHP整数取余返回负数的相关解决方法
May 15 PHP
实现在同一方法中获取当前方法中新赋值的session值解决方法
Jun 26 PHP
ecshop后台编辑器替换成ueditor编辑器
Mar 03 PHP
ThinkPHP2.x防范XSS跨站攻击的方法
Sep 25 PHP
汇总PHPmailer群发Gmail的常见问题
Feb 24 PHP
PHP数据库操作Helper类完整实例
May 11 PHP
如何使用Strace调试工具
Jun 03 #PHP
鸡肋的PHP单例模式应用详解
Jun 03 #PHP
phpize的深入理解
Jun 03 #PHP
PHP不用第三变量交换2个变量的值的解决方法
Jun 02 #PHP
基于php socket(fsockopen)的应用实例分析
Jun 02 #PHP
深入PHP操作MongoDB的技术总结
Jun 02 #PHP
深入php数据采集的详解
Jun 02 #PHP
You might like
Apache2中实现多网站域名绑定的实现方法
2011/06/01 PHP
PHP json_encode() 函数详解及中文乱码问题
2015/11/05 PHP
javascript 极速 隐藏/显示万行表格列只需 60毫秒
2009/03/28 Javascript
jQuery实现鼠标滑过遮罩并高亮显示效果
2013/07/16 Javascript
jquery中animate动画积累的解决方法
2013/10/05 Javascript
javascript + jquery实现定时修改文章标题
2014/03/19 Javascript
JQuery遍历json数组的3种方法
2014/11/08 Javascript
在 Express 中使用模板引擎
2015/12/10 Javascript
jquery.validate提示错误信息位置方法
2016/01/22 Javascript
JS实现图片平面旋转的方法
2016/03/01 Javascript
jquery基础知识第一讲之认识jquery
2016/03/17 Javascript
javascript拖拽效果延伸学习
2016/04/04 Javascript
微信小程序  modal详解及实例代码
2016/11/09 Javascript
如何用JS/HTML将时间戳转换为“xx天前”的形式
2017/02/06 Javascript
基于VUE选择上传图片并页面显示(图片可删除)
2017/05/25 Javascript
自定义PC微信扫码登录样式写法
2017/12/12 Javascript
JS计算输出100元钱买100只鸡问题的解决方法
2018/01/04 Javascript
JavaScript满天星导航栏实现方法
2018/03/08 Javascript
bootstrap模态框关闭后清除模态框的数据方法
2018/08/10 Javascript
[01:07:19]DOTA2-DPC中国联赛 正赛 CDEC vs XG BO3 第一场 1月19日
2021/03/11 DOTA
详解Python中的__new__()方法的使用
2015/04/09 Python
查看Django和flask版本的方法
2018/05/14 Python
python 读写文件,按行修改文件的方法
2018/07/12 Python
对python 匹配字符串开头和结尾的方法详解
2018/10/27 Python
Python 使用Numpy对矩阵进行转置的方法
2019/01/28 Python
python调用并链接MATLAB脚本详解
2019/07/05 Python
翻转数列python实现,求前n项和,并能输出整个数列的案例
2020/05/03 Python
使用python把xmind转换成excel测试用例的实现代码
2020/10/12 Python
CSS3实现王者荣耀匹配人员加载页面的方法
2019/04/16 HTML / CSS
优衣库澳大利亚官网:UNIQLO澳大利亚
2017/01/18 全球购物
贪睡宠物用品:Snoozer Pet Products
2020/02/04 全球购物
十佳教师事迹材料
2014/01/11 职场文书
优秀毕业生求职信
2014/06/05 职场文书
绿色环保标语
2014/06/12 职场文书
村当支部个人对照检查材料思想汇报
2014/10/06 职场文书
员工安全责任协议书
2016/03/22 职场文书