`
Michaelmatrix
  • 浏览: 209575 次
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

core dump的生成与调试

 
阅读更多

在Linux下产生并调试core文件

URL: http://blog.china-pub.com/more.asp?name=uniware&id=35478

先看看我用的是个什么机器:

$ uname -a
Linux dev 2.4.21-9.30AXsmp #1 SMP Wed May 26 23:37:09 EDT 2004 i686 i686 i386 GNU/Linux

再看看默认的一些参数,注意core file size是个0,程序出错时不会产生core文件了。

$ ulimit -a
core file size (blocks, -c) 0
data seg size (kbytes, -d) unlimited
file size (blocks, -f) unlimited
max locked memory (kbytes, -l) 4
max memory size (kbytes, -m) unlimited
open files (-n) 2048
pipe size (512 bytes, -p) 8
stack size (kbytes, -s) 10240
cpu time (seconds, -t) unlimited
max user processes (-u) 7168
virtual memory (kbytes, -v) unlimited

写个简单的程序,看看core文件是不是会被产生。

$ more foo.c

#include <stdio.h>

static void sub(void);

int main(void)
{
sub();
return 0;
}

static void sub(void)
{
int *p = NULL;

/* derefernce a null pointer, expect core dump. */
printf("%d", *p);

}

$ gcc -Wall -g foo.c
$ ./a.out
Segmentation fault

$ ls -l core.*
ls: core.*: No such file or directory

没有找到core文件,我们改改ulimit的设置,让它产生。1024是随便取的,要是core文件大于1024个块,就产生不出来了。

$ ulimit -c 1024 (转者注: 使用-c unlimited不限制core文件大小)

$ ulimit -a
core file size (blocks, -c) 1024
data seg size (kbytes, -d) unlimited
file size (blocks, -f) unlimited
max locked memory (kbytes, -l) 4
max memory size (kbytes, -m) unlimited
open files (-n) 2048
pipe size (512 bytes, -p) 8
stack size (kbytes, -s) 10240
cpu time (seconds, -t) unlimited
max user processes (-u) 7168
virtual memory (kbytes, -v) unlimited

$ ./a.out
Segmentation fault (core dumped)
$ ls -l core.*
-rw------- 1 uniware uniware 53248 Jun 30 17:10 core.9128

注意看上述的输出信息,多了个(core dumped) 。确实产生了一个core文 件,9128是该进程的PID。我们用GDB来看看这个core。

$ gdb --core=core.9128 (gdb -c corefile execfile)
GNU gdb Asianux (6.0post-0.20040223.17.1AX)
Copyright 2004 Free Software Foundation, Inc.
GDB is free software, covered by the GNU General Public License, and you are
welcome to change it and/or distribute copies of it under certain conditions.
Type "show copying" to see the conditions.
There is absolutely no warranty for GDB. Type "show warranty" for details.
This GDB was configured as "i386-asianux-linux-gnu".
Core was generated by `./a.out'.
Program terminated with signal 11, Segmentation fault.
#0 0x08048373 in ?? ()
(gdb) bt
#0 0x08048373 in ?? ()
#1 0xbfffd8f8 in ?? ()
#2 0x0804839e in ?? ()
#3 0xb74cc6b3 in ?? ()
#4 0x00000000 in ?? ()

此时用bt看不到b ackt race,也就是调用堆栈,原来GDB还不知道符号信息在哪里。我们告诉它一下:

(gdb) file ./a.out
Reading symbols from ./a.out...done.
Using host libthread_db library "/lib/tls/libthread_db.so.1".
(gdb) bt
#0 0x08048373 in sub () at foo.c:17
#1 0x08048359 in main () at foo.c:8


此时backtrace出来了。

(gdb) l
8 sub();
9 return 0;
10 }
11
12 static void sub(void)
13 {
14 int *p = NULL;
15
16 /* derefernce a null pointer, expect core dump. */
17 printf("%d", *p);

分享到:
评论

相关推荐

    qt vs编译器下生成dump文件,方便调试。

    qt vs编译器下生成dump文件,方便调试。

    如何使用coredump

    在一个程序崩溃时,它一般会在指定目录下生成一个core文件。core文件仅仅是一个内存映象(同时加上调试信息),主要是用来调试的。

    dump调试样例分析

    很多人写的程序会莫名其妙地崩溃,弹出的崩溃...这个时候dump文件就会发挥大用处了,程序崩溃时自动生成.dmp文件,再利用windbg工具就能确定问题出在哪里了,具体可以看我的blog上面:http://blog.csdn.net/wu_123_456

    C++(Qt)软件崩溃调试-学会使用ProcDump (5)20230402.pdf

    1. 之前用过的方法DbgHelp、qBreakpad生成Dump、Linux下配置ulimit -c unlimited生成core的方式功能都比较单一,并且需要配置环境,在程序中调用库,使用较为复杂。 2. 而ProcDump 使用非常简单,不需要配置环境,不...

    C++(Qt)软件崩溃调试-学会使用ProcDump(5)20230403.pdf

    1. 之前用过的方法DbgHelp、qBreakpad生成Dump、Linux下配置ulimit -c unlimited生成core的方式功能都比较单一,并且需要配置环境,在程序中调用库,使用较为复杂。 2. 而ProcDump 使用非常简单,不需要配置环境,不...

    C++(Qt)软件崩溃调试-学会使用ProcDump.7z

    1. 之前用过的方法DbgHelp、qBreakpad生成Dump、Linux下配置ulimit -c unlimited生成core的方式功能都比较单一,并且需要配置环境,在程序中调用库,使用较为复杂。 2. 而ProcDump 使用非常简单,不需要配置环境,不...

    google_breakpad源码

    breakpad是google开发的一个跨平台C/C++ dump捕获开源库和工具套件,可用来发布删除了编译器调试信息的应用程序。在程序崩溃时,将崩溃信息记录在一个小巧的微软minidump格式文件中,支持将其发送回服务器,并且可以...

    su_dung_gdb:手动gdbgdbserver调试Linux中的程序

    它可以帮助我们了解导致coredump的代码(当程序崩溃并生成程序的coredump时)。 通过断点,我们知道程序是否通过该代码运行,以及当时的全局变量/局部变量的状态。 通过观察点,我们还可以查看是哪个代码导致对...

    flowtrace:用于追溯调试FBP程序的跟踪

    该概念类似于命令性代码的“ stacktrace”或“ core dump”。 该项目提供了用于存储跟踪的数据格式,并提供了用于处理这些跟踪的调试工具,以及用于记录和生成它们JavaScript库。 地位 在生产中 支持从1.3.0开始...

    Cisco故障诊断与排除结构化方法.rar

    3.11. 核心转储(CORE DUMP) 3.12. 小结 复习思考题 第4章 WAN介质(I)串行线路和X.25 故障诊断与排除 4.1 简介 4.2 HDLC串行链路故障诊断与排除 4.2.1 show interface命令 4.2.2 CSU/DSU返回测试...

    cisco_internetworking_and_troubleshooting.9569975735.zip

    3.11. 核心转储(CORE DUMP) 3.12. 小结 复习思考题 第4章 WAN介质(I)串行线路和X.25 故障诊断与排除 4.1 简介 4.2 HDLC串行链路故障诊断与排除 4.2.1 show interface命令 4.2.2 CSU/DSU返回测试...

    Ubuntu权威指南(2/2)

    3.6 元字符与文件名生成 67 3.7 转义与引用 69 3.8 命令历史 72 3.8.1 fc命令 72 3.8.2 history命令 74 3.8.3 重复执行先前的命令 75 3.8.4 编辑并执行校正后的命令 76 3.8.5 命令行补充 77 3.9 命令别名 79 3.10 ...

    Ubuntu权威指南(1/2)

    3.6 元字符与文件名生成 67 3.7 转义与引用 69 3.8 命令历史 72 3.8.1 fc命令 72 3.8.2 history命令 74 3.8.3 重复执行先前的命令 75 3.8.4 编辑并执行校正后的命令 76 3.8.5 命令行补充 77 3.9 命令别名 79 3.10 ...

    UbuntuChina12

    3.6 元字符与文件名生成 67 3.7 转义与引用 69 3.8 命令历史 72 3.8.1 fc命令 72 3.8.2 history命令 74 3.8.3 重复执行先前的命令 75 3.8.4 编辑并执行校正后的命令 76 3.8.5 命令行补充 77 3.9 命令别名 79 3.10 ...

    Apache HTTP Server Version 2.2 文档(2013.4.10最新)

    httxt2dbm - 生成RewriteMap指令使用的dbm文件 服务器和支持程序 logresolve - 解析Apache日志中的IP地址为主机名 其他程序 rotatelogs - 滚动Apache日志的管道日志程序 suexec - 在执行外部程序之前切换用户 URL...

    Oracle9i的init.ora参数中文说明

    ), interpreted (然后 PL/SQL 模块将被编译为 PL/SQL 字节代码格式), debug (PL/SQL 模块将用探测调试符号来编译), non_debug。 默认值: " interpreted, non_debug " plsql_native_linker: 说明: 此参数指定链接...

    《你必须知道的495个C语言问题》

    2.19 程序运行正确,但退出时却“core dump ”(核心转储)了,怎么回事? 29 联合 30 2.20 结构和联合有什么区别? 30 2.21 有办法初始化联合吗? 30 2.22 有没有一种自动方法来跟踪联合的哪个域在使用? ...

    你必须知道的495个C语言问题

    2.19 程序运行正确,但退出时却“coredump”(核心转储)了,怎么回事? 联合 2.20 结构和联合有什么区别? 2.21 有办法初始化联合吗? 2.22 有没有一种自动方法来跟踪联合的哪个域在使用? 枚举 2.23 枚举...

Global site tag (gtag.js) - Google Analytics