基于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 相关文章推荐
第七节 类的静态成员 [7]
Oct 09 PHP
php注入实例
Oct 09 PHP
php采集速度探究总结(原创)
Apr 18 PHP
php 代码优化的42条建议 推荐
Sep 25 PHP
php park、unpark、ord 函数使用方法(二进制流接口应用实例)
Oct 19 PHP
CodeIgniter中使用cookie的三种方式详解
Jul 18 PHP
PHP实现将科学计数法转换为原始数字字符串的方法
Dec 16 PHP
php+xml实现在线英文词典查询的方法
Jan 23 PHP
php使用正则表达式进行字符串搜索的方法
Mar 23 PHP
PHP基于GD库实现的生成图片缩略图函数示例
Jul 05 PHP
PHP实现类似题库抽题效果
Aug 16 PHP
PHP实现简单用户登录界面
Oct 23 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 反射机制实现动态代理的代码
2008/10/22 PHP
php Notice: Undefined index 错误提示解决方法
2010/08/29 PHP
PHP使用xmllint命令处理xml与html的方法
2014/12/15 PHP
laravel框架添加数据,显示数据,返回成功值的方法
2019/10/11 PHP
escape、encodeURI 和 encodeURIComponent 的区别
2009/03/02 Javascript
Javascript面象对象成员、共享成员变量实验
2010/11/19 Javascript
Node.js 异步编程之 Callback介绍(一)
2015/03/30 Javascript
js实现左侧网页tab滑动门效果代码
2015/09/06 Javascript
基于jQuery实现仿百度首页选项卡切换效果
2016/05/29 Javascript
浅谈js基本数据类型和typeof
2016/08/09 Javascript
jQuery Easy UI中根据第一个下拉框选中的值设置第二个下拉框是否可以编辑
2016/11/29 Javascript
node.js平台下的mysql数据库配置及连接
2017/03/31 Javascript
Nodejs读取文件时相对路径的正确写法(使用fs模块)
2017/04/27 NodeJs
微信小程序获取微信运动步数的实例代码
2017/07/20 Javascript
浅谈vue-router2路由参数注意的问题
2017/11/08 Javascript
JS实现DOM删除节点操作示例
2018/04/04 Javascript
Node.js使用cookie保持登录的方法
2018/05/11 Javascript
VUE v-for循环中每个item节点动态绑定不同函数的实例
2018/09/26 Javascript
点击按钮弹出模态框的一系列操作代码实例
2019/03/29 Javascript
vue和小程序项目中使用iconfont的方法
2020/05/19 Javascript
微信小程序用户登录和登录态维护的实现
2020/12/10 Javascript
跟老齐学Python之dict()的操作方法
2014/09/24 Python
Python3实现并发检验代理池地址的方法
2016/09/18 Python
Python中str is not callable问题详解及解决办法
2017/02/10 Python
Python列表切片操作实例总结
2019/02/19 Python
将matplotlib绘图嵌入pyqt的方法示例
2020/01/08 Python
使用python修改文件并立即写回到原始位置操作(inplace读写)
2020/06/28 Python
Alpine安装Python3依赖出现的问题及解决方法
2020/12/25 Python
python如何调用php文件中的函数详解
2020/12/29 Python
企业管理培训感言
2014/01/27 职场文书
民族团结演讲稿范文
2014/08/27 职场文书
六一亲子活动感想
2015/08/07 职场文书
CocosCreator入门教程之网络通信
2021/04/16 Javascript
Python初学者必备的文件读写指南
2021/06/23 Python
Python 多线程处理任务实例
2021/11/07 Python
Nginx动静分离配置实现与说明
2022/04/07 Servers