基于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怎样调用MSSQL的存储过程
Oct 09 PHP
某大型网络公司应聘时的笔试题目附答案
Mar 27 PHP
php获取post中的json数据的实现方法
Jun 08 PHP
php读取txt文件组成SQL并插入数据库的代码(原创自Zjmainstay)
Jul 31 PHP
PHPMailer发送HTML内容、带附件的邮件实例
Jul 01 PHP
php更新mysql后获取改变行数的方法
Dec 25 PHP
Yii2 输出xml格式数据的方法
May 03 PHP
PHP通过加锁实现并发情况下抢码功能
Aug 10 PHP
PHP使用mysqli操作MySQL数据库的简单方法
Feb 04 PHP
PHP编程获取音频文件时长的方法【基于getid3类】
Apr 20 PHP
PHP命令Command模式用法实例分析
Aug 08 PHP
一文搞懂PHP中的抽象类和接口
May 25 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 求质素(素数) 的实现代码
2011/04/12 PHP
Laravel 5 学习笔记
2015/03/06 PHP
轻松掌握php设计模式之访问者模式
2016/09/23 PHP
Laravel5.1框架路由分组用法实例分析
2020/01/04 PHP
js获取div高度的代码
2008/08/09 Javascript
php上传图片并给图片打上透明水印的代码
2010/06/07 Javascript
JavaScript高级程序设计(第3版)学习笔记9 js函数(下)
2012/10/11 Javascript
Jquery ajaxStart()与ajaxStop()方法(实例讲解)
2013/12/18 Javascript
jQuery实现返回顶部功能
2016/02/23 Javascript
JavaScript新增样式规则(推荐)
2016/07/19 Javascript
jQuery插件FusionCharts绘制2D环饼图效果示例【附demo源码】
2017/04/10 jQuery
vue使用Axios做ajax请求详解
2017/06/07 Javascript
详解Webpack + ES6 最新环境搭建与配置
2018/06/04 Javascript
vue中的自定义分页插件组件的示例
2018/08/18 Javascript
从零到一详聊创建Vue工程及遇到的常见问题
2019/04/25 Javascript
详解微信UnionID作用
2019/05/15 Javascript
JS实现求字符串中出现最多次数的字符和次数示例
2019/07/05 Javascript
Element-UI中关于table表格的那些骚操作(小结)
2019/08/15 Javascript
微信域名检测接口调用演示步骤(含PHP、Python)
2019/12/08 Javascript
Python高效编程技巧
2013/01/07 Python
详解Python3 中hasattr()、getattr()、setattr()、delattr()函数及示例代码数
2018/04/18 Python
详解python多线程、锁、event事件机制的简单使用
2018/04/27 Python
在matplotlib的图中设置中文标签的方法
2018/12/13 Python
Python中函数参数匹配模型详解
2019/06/09 Python
python 初始化一个定长的数组实例
2019/12/02 Python
Python 过滤错误log并导出的实例
2019/12/26 Python
使用css3 属性如何丰富图片样式(圆角 阴影 渐变)
2012/11/22 HTML / CSS
html5唤起app的方法
2017/11/30 HTML / CSS
俄罗斯珠宝市场的领导者之一:Бронницкий ювелир
2019/10/02 全球购物
2014年最新学习全国两会精神心得
2014/03/17 职场文书
《二泉映月》教学反思
2014/04/15 职场文书
先进个人事迹材料范文
2014/12/30 职场文书
数学教师个人工作总结
2015/02/06 职场文书
工作能力自我评价2015
2015/03/05 职场文书
出纳岗位职责范本
2015/03/31 职场文书
MySQL创建定时任务
2022/01/22 MySQL