基于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 相关文章推荐
15种PHP Encoder的比较
Apr 17 PHP
php下使用strpos需要注意 === 运算符
Jul 17 PHP
PHP daddslashes 使用方法介绍
Oct 26 PHP
PHP队列用法实例
Nov 05 PHP
thinkphp文件引用与分支结构用法实例
Nov 26 PHP
PHP查询快递信息的方法
Mar 07 PHP
摘自织梦CMS中的图片处理类
Aug 08 PHP
PHP入门教程之数学运算技巧总结
Sep 11 PHP
php 使用fopen函数创建、打开文件详解及实例代码
Sep 24 PHP
Laravel网站打开速度优化的方法汇总
Jul 16 PHP
PHP+swoole+linux实现系统监控和性能优化操作示例
Apr 15 PHP
PHP常用字符串函数用法实例总结
Jun 04 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/10/09 PHP
在Windows下编译适用于PHP 5.2.12及5.2.13的eAccelerator.dll(附下载)
2010/05/04 PHP
比file_get_contents稳定的curl_get_contents分享
2012/01/11 PHP
php生成局部唯一识别码LUID的代码
2012/10/06 PHP
PHP邮件群发机实现代码
2016/02/16 PHP
php解决和避免form表单重复提交的几种方法
2016/08/31 PHP
php中isset与empty函数的困惑与用法分析
2019/07/05 PHP
laravel 框架实现无限级分类的方法示例
2019/10/31 PHP
Jquery Ajax学习实例6 向WebService发出请求,返回DataSet(XML) 异步调用
2010/03/18 Javascript
document节点对象的获取方式示例介绍
2013/12/24 Javascript
jQuery遮罩层实例讲解
2017/05/11 jQuery
通过命令行生成vue项目框架的方法
2017/07/12 Javascript
vue根据值给予不同class的实例
2018/09/29 Javascript
浅谈javascript错误处理
2019/08/11 Javascript
浅谈vue权限管理实现及流程
2020/04/23 Javascript
python实现颜色rgb和hex相互转换的函数
2015/03/19 Python
python统计文本文件内单词数量的方法
2015/05/30 Python
用Python解决计数原理问题的方法
2016/08/04 Python
Python Lambda函数使用总结详解
2019/12/11 Python
Python类中self参数用法详解
2020/02/13 Python
使用CSS实现阅读进度条
2017/02/27 HTML / CSS
HTML5+JS实现俄罗斯方块原理及具体步骤
2013/11/29 HTML / CSS
北大研究生linux应用求职信
2013/10/29 职场文书
工程项目经理岗位职责
2013/12/15 职场文书
二手房买卖协议书
2014/04/10 职场文书
庆元旦演讲稿
2014/09/15 职场文书
孕妇离婚协议书范本
2014/11/20 职场文书
师德师风个人总结
2015/02/06 职场文书
幼儿园小班工作总结2015
2015/04/25 职场文书
周恩来的四个昼夜观后感
2015/06/03 职场文书
董事长助理工作总结2015
2015/07/23 职场文书
预备党员入党感想
2015/08/10 职场文书
你离财务总监还有多远?速览CFO的岗位职责
2019/11/18 职场文书
nginx网站服务如何配置防盗链(推荐)
2021/03/31 Servers
纯 CSS 自定义多行省略的问题(从原理到实现)
2021/11/11 HTML / CSS
Python学习之异常中的finally使用详解
2022/03/16 Python