基于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 相关文章推荐
多重?l件?合查?(二)
Oct 09 PHP
探讨各种PHP字符串函数的总结分析
Jun 05 PHP
PHP转换IP地址到真实地址的方法详解
Jun 09 PHP
sae使用smarty模板的方法
Dec 17 PHP
php写的AES加密解密类分享
Jun 20 PHP
PHP向socket服务器收发数据的方法
Jan 24 PHP
thinkPHP模板中for循环与switch语句用法示例
Nov 30 PHP
详解PHP中的序列化、反序列化操作
Mar 21 PHP
mac系统下安装多个php并自由切换的方法详解
Apr 21 PHP
PHP截取发动短信内容的方法
Jul 04 PHP
php更新cookie内容的详细方法
Sep 30 PHP
Yii框架where查询用法实例分析
Oct 22 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多维数组去掉重复值示例分享
2014/03/02 PHP
ThinkPHP中I(),U(),$this->post()等函数用法
2014/11/22 PHP
js 刷新页面的代码小结 推荐
2010/04/02 Javascript
事件绑定之小测试  onclick && addEventListener
2011/07/31 Javascript
JS实现带缓冲效果打开、关闭、移动一个层的方法
2015/05/09 Javascript
JavaScript使用addEventListener添加事件监听用法实例
2015/06/01 Javascript
jQuery实现鼠标悬停背景翻转的黑色导航菜单代码
2015/09/14 Javascript
Angular.js如何从PHP读取后台数据
2016/03/24 Javascript
ES6概念 Symbol toString()方法
2016/12/25 Javascript
AngularJS路由实现页面跳转实例
2017/03/03 Javascript
js+html制作简单日历的方法
2017/06/27 Javascript
ES6学习之变量的两种命名方法示例
2017/07/18 Javascript
vue组件之Alert的实现代码
2017/10/17 Javascript
vue watch监听对象及对应值的变化详解
2018/02/24 Javascript
js实现动态改变radio状态的方法
2018/02/28 Javascript
详解Eslint 配置及规则说明
2018/09/10 Javascript
Vue实现简单分页器
2018/12/29 Javascript
layui使用数据表格实现购物车功能
2019/07/26 Javascript
vue中axios的二次封装实例讲解
2019/10/14 Javascript
Vue Cli3 打包配置并自动忽略console.log语句的方法
2020/04/23 Javascript
python实现人脸识别代码
2017/11/08 Python
详解Python3中ceil()函数用法
2019/02/19 Python
Python单元和文档测试实例详解
2019/04/11 Python
python生成大写32位uuid代码
2020/03/03 Python
django自定义非主键自增字段类型详解(auto increment field)
2020/03/30 Python
Python selenium文件上传下载功能代码实例
2020/04/13 Python
使用PyCharm安装pytest及requests的问题
2020/07/31 Python
python开发入门——set的使用
2020/09/03 Python
Python实现京东抢秒杀功能
2021/01/25 Python
运动鞋中的劳斯莱斯:索康尼(SAUCONY)
2017/08/09 全球购物
2014年领班工作总结
2014/11/25 职场文书
采购员岗位职责
2015/02/03 职场文书
大学生个人简历自我评价
2015/03/11 职场文书
2015年车间主任工作总结
2015/05/21 职场文书
浅谈Python 中的复数问题
2021/05/19 Python
Python列表的索引与切片
2022/04/07 Python