目前在开发linux下面的一个c项目,debug目前主要靠日志来定位问题。
想问问linux下有什么好的方法debug吗?定位问题。
比如突然process crash了,怎么知道是哪一句代码出问题的?
目前在开发linux下面的一个c项目,debug目前主要靠日志来定位问题。
想问问linux下有什么好的方法debug吗?定位问题。
比如突然process crash了,怎么知道是哪一句代码出问题的?
编译的时候加上-g3
或者-ggdb3
,如果能捡到core文件,用gdb xx core
,然后bt
一下,回溯崩溃前的调用栈,多半可以定位到到底是执行到哪一部分发生了崩溃。
process crash 不是有coredump文件可以查看吗。。题主参考:UNIX 程序常见问题的分析方法
http://www.ibm.com/developerworks/cn/aix/library/1206_yudh_unixproblemsolve/
7 回答5.6k 阅读
4 回答4.3k 阅读
2 回答973 阅读✓ 已解决
2 回答3.5k 阅读
1 回答1.2k 阅读✓ 已解决
2 回答1.5k 阅读✓ 已解决
1 回答596 阅读✓ 已解决
gdb的三种用法;
1.调试自运行的可只执行程序;
比如自己写的myProgrammer. 编译的过程加上-g标识符,调试通过以下方式启动:
2.调试coredump文件;
某个进程有bug,突然crash了,如果系统打开了core dump标志,则会留下coredump文件(eg:core.71818):
调试core dump文件启动方式:
3.调试服务程序;
某个进程myService正在运行中,将gdb挂上去调试方法:
1)找到这个进程的进程号pid:
2) gdb挂上去后调试:
关于gdb中通用调试命令的总结,请见《linux工具快速教程》gdb节:
http://linuxtools-rst.readthedocs.org/zh_CN/latest/tool/gdb.html
关于linux程序调试还有很多工具,比如pstack等等,详见程序调试:
http://linuxtools-rst.readthedocs.org/zh_CN/latest/advance/02_program_debug.html
附:需要进程crash后产生core dump文件,需要设置下系统:
1.core文件的生成开关和大小限制
1)使用ulimit -c命令可查看core文件的生成开关。若结果为0,则表示关闭了此功能,不会生成core文件。
ulimit -a :查看全部
ulimit -n:查看可以打开的文件句柄数目;
2)打开core开关
使用ulimit -c filesize命令,可以限制core文件的大小(filesize的单位为blocks)。
若ulimit -c unlimited,则表示core文件的大小不受限制。如果生成的信息超过此大小,将会被裁剪,最终生成一个不完整的core文件。在调试此core文件的时候,gdb会提示错误。