gdb调试-dump
来源:互联网 发布:王健林 鲁豫 知乎 编辑:程序博客网 时间:2024/06/05 12:44
gdb结合coredump定位崩溃进程
lazycat posted @ 2012年2月02日 09:35 in linux , 18166 阅读
Linux环境下经常遇到某个进程挂掉而找不到原因,我们可以通过生成core file文件加上gdb来定位。
如何产生core file?
我们可以使用ulimit这条命令对core file文件的大小进行设定。
一般默认情况下,core file的大小被设置为了0,这样系统就不dump出core file了。
这时用如下命令进行设置:
ulimit -c unlimited
这样便把core file的大小设置为了无限大,同时也可以使用数字来替代unlimited,对core file的上限值做更精确的设定。
生成的core file在哪里?
core file生成的地方是在/proc/sys/kernel/core_pattern文件定义的。
改动到生成到自己定义的目录的方法是:
echo “pattern” > /proc/sys/kernel/core_pattern
并且只有超级用户可以修改这两个文件。
“pattern”类似我们C语言打印字符串的格式,相关标识如下:
%%: 相当于%
%p: 相当于pid
%u: 相当于uid
%g: 相当于gid
%s: 相当于导致dump的信号的数字
%t: 相当于dump的时间
%h: 相当于hostname
%e: 相当于执行文件的名称
这时用如下命令设置生成的core file到系统/tmp目录下,并记录pid以及执行文件名
echo “/tmp/core-%e-%p” > /proc/sys/kernel/core_pattern
测试如下代码
?
1
2
3
4
5
6
7
8
9
10
11
12
#include <stdio.h>int func(int *p){ *p = 0;}int main(){ func(NULL); return 0;}
生成可执行文件并运行
gcc -o main a.c
root@ubuntu:~# ./main
Segmentation fault (core dumped)
<—–这里出现段错误并生成core文件了。
在/tmp目录下发现文件core-main-10815
如何查看进程挂在哪里了?
我们可以用
gdb main /tmp/core-main-10815
查看信息,发现能定位到函数了
Program terminated with signal 11, Segmentation fault.#0 0x080483ba in func ()
如何定位到行?
在编译的时候开启-g调试开关就可以了
gcc -o main -g a.c
gdb main /tmp/core-main-10815
最终看到的结果如下,好棒。
Program terminated with signal 11, Segmentation fault.#0 0x080483ba in func (p=0x0) at a.c:55 *p = 0;
总结一下,需要定位进程挂在哪一行我们只需要4个操作,
ulimit -c unlimited
echo “/tmp/core-%e-%p” > /proc/sys/kernel/core_pattern
gcc -o main -g a.c
gdb main /tmp/core-main-10815
就可以啦。
补充说明:
相关常用gdb命令
1,(gdb) backtrace /* 查看当前线程函数栈回溯 */
以上面的例子为例
Program terminated with signal 11, Segmentation fault.#0 0x080483ba in func (p=0x0) at main.c:55 *p = 0;(gdb) backtrace#0 0x080483ba in func (p=0x0) at main.c:5#1 0x080483d4 in main () at main.c:10
如果是多线程环境下(gdb) thread apply all backtrace /* 显示所有线程栈回溯 */
2,(gdb) print [var] /* 查看变量值 */
(gdb) print p
1 = (int *) 0x0
(gdb) print &p2 = (int **) 0xbf96d4d4
3,(gdb) x/FMT [Address] /* 根据格式查看地址指向的值 */
其中
FMT is a repeat count followed by a format letter and a size letter.
Format letters are o(octal), x(hex), d(decimal), u(unsigned decimal),
t(binary), f(float), a(address), i(instruction), c(char) and s(string).
Size letters are b(byte), h(halfword), w(word), g(giant, 8 bytes).
The specified number of objects of the specified size are printed
according to the format.
(gdb) x/d 0xbf96d4d4
0xbf96d4d4: 0
(gdb) x/c 0xbf96d4d4
0xbf96d4d4: 0 ‘\000’
另外能导致产生core file文件的信号有以下10种
SIGQUIT:终端退出符
SIGILL:非法硬件指令
SIGTRAP:平台相关的硬件错误,现在多用在实现调试时的断点
SIGBUS:与平台相关的硬件错误,一般是内存错误
SIGABRT:调用abort函数时产生此信号,进程异常终止
SIGFPE:算术异常
SIGSEGV:segment violation,无效内存引用
SIGXCPU:超过了cpu使用资源限制(setrlimit)
SIGXFSZ:超过了文件长度限制(setrlimit)
SIGSYS:无效的系统调用
http://lazycat.is-programmer.com/posts/31925.html
gdb core 调试
http://blog.csdn.net/hanchaoman/article/details/5583457
gdb参数及命令详解 (已整理) core dump调试
http://blog.csdn.net/ghostyu/article/details/8083228
gdb调试命令的使用及总结
http://www.jb51.net/article/36393.htm
GDB基本命令(整合)
http://blog.csdn.net/water_cow/article/details/7214054
在宿主目录下修改.bashrc配置文件中添加 ulimit -c unlimited ,修改完.bashrc文件后运行. .bashrc让文件修改生效
Linux 中gdb调试工具的使用
- gdb调试-dump
- gdb调试core dump文件
- 用gdb调试core dump文件
- 用gdb调试core dump文件
- gdb Core Dump 调试程序错误
- 用gdb调试core dump文件
- 用gdb调试core dump文件
- 用gdb调试core dump文件
- 用gdb调试core dump文件
- LINUX core dump详解 & GDB调试
- 用gdb调试core dump文件
- 用gdb调试core dump文件
- 使用 GDB 调试 core dump 文件
- 用GDB调试core dump文件
- gdb core dump调试程序错误
- GDB调试core dump文件示例
- 用gdb调试core dump文件
- 关于gdb调试core dump文件
- iOS利用Xcode制作静态库和动态库
- Mysql 执行外部脚本
- Java经典算法——窃贼问题
- 两个host上的qemu VM使用bridge互通
- 文章标题
- gdb调试-dump
- ps动作储存覆盖原文件的原因
- python实现感知机(perceptron)原型~
- windows平台搭带c++扩展的nodejs环境
- ES7中的异步编程,虽然我ES6还没有学会
- 2017.03.25暑期实习在线笔试
- jquery事件冒泡,阻止事件冒泡
- Spring MVC Josn格式注解
- 自定义View练习(二)二阶贝塞尔曲线