基于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也可以?成Shell Script
Oct 09 PHP
文章推荐系统(二)
Oct 09 PHP
PHP4之COOKIE支持详解
Oct 09 PHP
COM in PHP (winows only)
Oct 09 PHP
PHP添加MySQL数据记录代码
Jun 07 PHP
解析yii数据库的增删查改
Jun 20 PHP
解析php addslashes()与addclashes()函数的区别和比较
Jun 24 PHP
php json_encode()函数返回json数据实例代码
Oct 10 PHP
PHP+MySQL删除操作实例
Jan 21 PHP
php自定义错误处理用法实例
Mar 20 PHP
php页面跳转session cookie丢失导致不能登录等问题的解决方法
Dec 12 PHP
Laravel框架使用Seeder实现自动填充数据功能
Jun 13 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语法(2)
2006/10/09 PHP
需要发散思维学习PHP
2009/06/29 PHP
php缩放图片(根据宽高的等比例缩放)实例介绍
2013/06/09 PHP
php在linux下检测mysql同步状态的方法
2015/01/15 PHP
round robin权重轮循算法php实现代码
2016/05/28 PHP
Javascript Select操作大集合
2009/05/26 Javascript
js判断生效时间不得大于失效时间的思路及代码
2013/04/23 Javascript
javascript和HTML5利用canvas构建猜牌游戏实现算法
2013/07/17 Javascript
原生javascript+css3编写的3D魔方动画旋扭特效
2016/03/14 Javascript
JS实现简单的二元方程计算器功能示例
2017/01/03 Javascript
基于js 各种排序方法和sort方法的区别(详解)
2018/01/03 Javascript
Vue中使用Sortable的示例代码
2018/04/07 Javascript
20个最常见的jQuery面试问题及答案
2018/05/23 jQuery
详解浏览器缓存和webpack缓存配置
2018/07/06 Javascript
Vue computed 计算属性代码实例
2020/04/22 Javascript
vue实现两个组件之间数据共享和修改操作
2020/11/12 Javascript
[02:08]我的刀塔不可能这么可爱 胡晓桃_1
2014/06/20 DOTA
python新手经常遇到的17个错误分析
2014/07/30 Python
python Django模板的使用方法
2016/01/14 Python
Python解析树及树的遍历
2016/02/03 Python
Python实现的连接mssql数据库操作示例
2018/08/17 Python
使用python实现数组、链表、队列、栈的方法
2019/12/20 Python
详解Django中views数据查询使用locals()函数进行优化
2020/08/24 Python
python读取excel数据并且画图的实现示例
2021/02/08 Python
美国百货齐全的精品网站,提供美式风格的产品:Overstock.com
2016/07/22 全球购物
瑞典最大的儿童用品网上商店:pinkorblue.se
2021/03/09 全球购物
法律专业应届生自荐信范文
2014/01/06 职场文书
北京奥运会主题口号
2014/06/13 职场文书
村长党的群众路线教育实践活动个人对照检查材料
2014/09/23 职场文书
2014年学前班工作总结
2014/12/08 职场文书
先进班集体事迹材料
2014/12/25 职场文书
检讨书格式
2015/01/23 职场文书
奔腾年代观后感
2015/06/09 职场文书
十七岁的单车观后感
2015/06/12 职场文书
公司庆典主持词
2015/07/04 职场文书
golang日志包logger的用法详解
2021/05/05 Golang