基于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 静态页面中显示动态内容
Aug 14 PHP
PHP程序开发范例学习之表单 获取文本框的值
Aug 08 PHP
实例介绍PHP的Reflection反射机制
Aug 05 PHP
php常用hash加密函数
Nov 22 PHP
php实现用已经过去多长时间的方式显示时间
Jun 05 PHP
PHP+MySQL之Insert Into数据插入用法分析
Sep 27 PHP
joomla实现注册用户添加新字段的方法
May 05 PHP
PHP MySql增删改查的简单实例
Jun 21 PHP
PHP实现自动识别原编码并对字符串进行编码转换的方法
Jul 13 PHP
php版微信开发Token验证失败或请求URL超时问题的解决方法
Sep 23 PHP
解决PHP 7编译安装错误:cannot stat ‘phar.phar’: No such file or directory
Feb 25 PHP
ThinkPHP3.2框架自带分页功能实现方法示例
May 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设计模式 Visitor 访问者模式
2011/06/28 PHP
PHP Directory 函数的详解
2013/03/07 PHP
php实现用已经过去多长时间的方式显示时间
2015/06/05 PHP
CodeIgniter记录错误日志的方法全面总结
2016/05/17 PHP
PHP实现路由映射到指定控制器
2016/08/13 PHP
Win10 下安装配置IIS + MySQL + nginx + php7.1.7
2017/08/04 PHP
滚动经典最新话题[prototype框架]下编写
2006/10/03 Javascript
用Javscript实现表单复选框的全选功能
2007/05/25 Javascript
JS 强制设为首页的代码
2009/01/31 Javascript
jquery+json实现的搜索加分页效果
2010/03/31 Javascript
window.open()详解及浏览器兼容性问题示例探讨
2014/05/29 Javascript
js获取客户端操作系统类型的方法【测试可用】
2016/05/27 Javascript
js 弹出对话框(遮罩)透明,可拖动的简单实例
2016/07/11 Javascript
基于JavaScript实现自动更新倒计时效果
2016/12/19 Javascript
nodejs和php实现图片访问实时处理
2017/01/05 NodeJs
node.js(express)中使用Jcrop进行图片剪切上传功能
2017/04/21 Javascript
bootstrap table服务端实现分页效果
2017/08/10 Javascript
Vue基于NUXT的SSR详解
2017/10/24 Javascript
React 组件转 Vue 组件的命令写法
2018/02/28 Javascript
vue实现点击选中,其他的不选中方法
2018/09/05 Javascript
小程序转发探索示例
2019/02/19 Javascript
vue 中使用 watch 出现了如下的报错的原因分析
2019/05/21 Javascript
vue封装swiper代码实例解析
2019/10/08 Javascript
JavaScript实现切换多张图片
2021/01/27 Javascript
[02:05]2014DOTA2西雅图邀请赛 老队长全明星大猜想谁不服就按进显示器
2014/07/08 DOTA
python print输出延时,让其立刻输出的方法
2019/01/07 Python
HTML5学习笔记之History API
2015/02/26 HTML / CSS
大学生简历的个人自我评价
2013/12/04 职场文书
兼职业务员岗位职责
2014/01/01 职场文书
最新奶茶店创业计划书范文
2014/02/08 职场文书
ktv好的活动方案
2014/08/17 职场文书
镇人大副主席民主生活会对照检查材料思想汇报
2014/10/01 职场文书
教育合作协议范本
2014/10/17 职场文书
党的群众路线教育实践活动整改落实情况自查报告
2014/10/28 职场文书
捐助感谢信
2015/01/22 职场文书
如何使用PostgreSQL进行中文全文检索
2021/05/27 PostgreSQL