基于Linux调试工具strace与gdb的常用命令总结


Posted in PHP onJune 03, 2013

strace和gdb是Linux环境下的两个常用调试工具,这里是个人在使用过程中对这两个工具常用参数的总结,留作日后查看使用。
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 whoami  #跟踪whoami可执行程序,每行输出结果前打印执行的时间
strace -p 17151 -p 17152 -p 17153  #同时跟踪进程17151、17152、17153
strace -f -e trace=read,write -p 17151 -o log  #跟踪进程17151及子进程中read和write系统调用,输出到log文件
gdb调试工具
GDB是GNU开源组织发布的一个强大的UNIX下的程序调试工具。gcc编译时加上-g参数,可以使可执行程序加上gdb调试信息。
(1)info
简写:i,列出gdb子命令的信息,如info break,info variables,info stack等。
(2)list [file:]function
简写:l,查看当前行的上下文,默认为10行,也可以设置在某个函数处列出源码。
(3)edit [file:]function
简写:e,编辑当前所在的行,也可以编辑某个函数的源码。
(4)break [file:]function
简写:b,设置断点,可以设置在某行或某个函数处。
(5)run [arglist]
简写:r,运行程序至断点处停住,run命令之后可以加上调试程序需要的参数。
(6)next
简写:n,单条语句执行。
(7)continue
简写:c,继续运行程序至下一个断点。
(8)print
简写:p,打印变量的值。
(9)bt
查看函数堆栈信息。
(10)enter
回车键,重复上一次调试命令。
(11)help [name]
显示指定的gdb命令的帮助信息。
(12)quit
简写:q,退出gdb。

PHP 相关文章推荐
测试您的 PHP 水平的题目
May 30 PHP
javascript some()函数用法详解
Nov 13 PHP
PHP之正则表达式捕获组与非捕获组(详解)
Jul 29 PHP
解析WordPress中函数钩子hook的作用及基本用法
Dec 22 PHP
PHP的全局错误处理详解
Apr 25 PHP
PHP编写文件多服务器同步程序
Jul 02 PHP
php getcwd与dirname(__FILE__)区别详解
Sep 24 PHP
PHP 7.1中AES加解密方法mcrypt_module_open()的替换方案
Oct 17 PHP
PHP+MySQL高并发加锁事务处理问题解决方法
Apr 30 PHP
PHP命名空间简单用法示例
Dec 28 PHP
laravel执行php artisan migrate报错的解决方法
Oct 09 PHP
php中配置文件保存修改操作 如config.php文件的读取修改等操作
May 12 PHP
linux命令之调试工具strace的深入分析
Jun 03 #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
You might like
PHP图片上传类带图片显示
2006/11/25 PHP
Php获取金书网的书名的实现代码
2010/06/11 PHP
thinkphp中U方法按路由规则生成url的方法
2018/03/12 PHP
jQueryPad 实用的jQuery测试工具(支持IE,chrome,FF)
2010/05/22 Javascript
jQuery参数列表集合
2011/04/06 Javascript
页面只能打开一次Cooike如何实现
2012/12/04 Javascript
输入自动提示搜索提示功能的使用说明:sugggestion.txt
2013/09/02 Javascript
JS数组去重与取重的示例代码
2014/01/24 Javascript
js处理表格对table进行修饰
2014/05/26 Javascript
JavaScript使用focus()设置焦点失败的解决方法
2014/09/03 Javascript
javascript动态添加删除tabs标签的方法
2015/07/06 Javascript
第六章之辅组类与响应式工具
2016/04/25 Javascript
JavaScript学习笔记整理_用于模式匹配的String方法
2016/09/19 Javascript
jQuery EasyUI右键菜单实现关闭标签/选项卡
2016/10/10 Javascript
使用JavaScript为一张图片设置备选路径的方法
2017/01/04 Javascript
Js自定义多选框效果的实例代码
2017/07/05 Javascript
详解动画插件wow.js的使用方法
2017/09/13 Javascript
JavaScript中的垃圾回收与内存泄漏示例详解
2019/05/02 Javascript
NodeJs生成sitemap站点地图的方法示例
2019/06/11 NodeJs
vue轮播组件实现$children和$parent 附带好用的gif录制工具
2019/09/26 Javascript
vue路由 遍历生成复数router-link的例子
2019/10/30 Javascript
[03:26]《DAC最前线》之EG经理自述DOTA2经历
2015/02/02 DOTA
python统计字符串中指定字符出现次数的方法
2015/04/04 Python
python机器学习理论与实战(四)逻辑回归
2018/01/19 Python
python实现媒体播放器功能
2018/02/11 Python
Python 切分数组实例解析
2019/11/07 Python
python使用ctypes调用扩展模块的实例方法
2020/01/28 Python
五款漂亮的纯CSS3动画按钮的实例教程
2014/11/21 HTML / CSS
Fossil美国官网:化石手表、手袋、首饰及配饰
2019/02/17 全球购物
求职简历自荐信范文
2013/10/21 职场文书
企业宣传方案
2014/03/04 职场文书
导师评语大全
2014/04/26 职场文书
中学生演讲稿
2014/04/26 职场文书
机关干部四风问题自我剖析及整改措施
2014/10/26 职场文书
离婚协议书范文2015
2015/01/26 职场文书
看上去很美观后感
2015/06/10 职场文书