linux下core dump 总结

本文详细介绍了Linux下core文件的生成机制及其配置方法。通过core dump,开发者能够获取程序崩溃时的内存状态,这对于调试和诊断难以复现的错误至关重要。文章不仅解释了如何通过ulimit命令或setrlimit系统调用开启core dump,还提供了示例代码,展示了如何在程序中设置core文件大小限制。

转载自:https://www.cnblogs.com/Anker/p/6079580.html

1、前言

  一直在从事linux下后台开发,经常与core文件打交道。还记得刚开始从事linux下开发时,程序突然崩溃了,也没有任何日志。我不知所措,同事叫我看看core,我却问什么是core,怎么看。同事鄙视的眼神,我依然在目。后来学会了从core文件中分析原因,通过gdb看出程序挂再哪里,分析前后的变量,找出问题的原因。当时就觉得很神奇,core文件是怎么产生的呢?难道系统会自动产生,可是我在自己的linux系统上面写个非法程序测试,并没有产生core问题?这又是怎么回事呢?今天在ngnix的源码时候,发现可以在程序中设置core dump,又是怎么回事呢?在公司发现生成的core文件都带有进程名称、进程ID、和时间,这又是怎么做到的呢?今天带着这些疑问来说说core文件是如何生成,如何配置。

2、基本概念

   当程序运行的过程中异常终止或崩溃,操作系统会将程序当时的内存状态记录下来,保存在一个文件中,这种行为就叫做Core Dump(中文有的翻译成“核心转储”)。我们可以认为 core dump 是“内存快照”,但实际上,除了内存信息之外,还有些关键的程序运行状态也会同时 dump 下来,例如寄存器信息(包括程序指针、栈指针等)、内存管理信息、其他处理器和操作系统状态和信息。core dump 对于编程人员诊断和调试程序是非常有帮助的,因为对于有些程序错误是很难重现的,例如指针异常,而 core dump 文件可以再现程序出错时的情景。

3、开启core dump

  可以使用命令ulimit开启,也可以在程序中通过setrlimit系统调用开启。

程序中开启core dump,通过如下API可以查看和设置RLIMIT_CORE

#include <sys/resource.h>

int getrlimit(int resource, struct rlimit *rlim);
int setrlimit(int resource, const struct rlimit *rlim);

参考程序如下所示:

复制代码
#include <unistd.h>
#include <sys/time.h>
#include <sys/resource.h>
#include <stdio.h>
#define CORE_SIZE   1024 * 1024 * 500
int main()
{
    struct rlimit rlmt;
    if (getrlimit(RLIMIT_CORE, &rlmt) == -1) {
        return -1; 
    }   
    printf("Before set rlimit CORE dump current is:%d, max is:%d\n", (int)rlmt.rlim_cur, (int)rlmt.rlim_max);
rlmt.rlim_cur </span>=<span style="color: #000000;"> (rlim_t)CORE_SIZE;
rlmt.rlim_max  </span>=<span style="color: #000000;"> (rlim_t)CORE_SIZE;

</span><span style="color: #0000ff;">if</span> (setrlimit(RLIMIT_CORE, &amp;rlmt) == -<span style="color: #800080;">1</span><span style="color: #000000;">) {
    </span><span style="color: #0000ff;">return</span> -<span style="color: #800080;">1</span><span style="color: #000000;">; 
}   

</span><span style="color: #0000ff;">if</span> (getrlimit(RLIMIT_CORE, &amp;rlmt) == -<span style="color: #800080;">1</span><span style="color: #000000;">) {
    </span><span style="color: #0000ff;">return</span> -<span style="color: #800080;">1</span><span style="color: #000000;">; 
}   
printf(</span><span style="color: #800000;">"</span><span style="color: #800000;">After set rlimit CORE dump current is:%d, max is:%d\n</span><span style="color: #800000;">"</span>, (<span style="color: #0000ff;">int</span>)rlmt.rlim_cur, (<span style="color: #0000ff;">int</span><span style="color: #000000;">)rlmt.rlim_max);

</span><span style="color: #008000;">/*</span><span style="color: #008000;">测试非法内存,产生core文件</span><span style="color: #008000;">*/</span>
<span style="color: #0000ff;">int</span> *ptr =<span style="color: #000000;"> NULL;
</span>*ptr = <span style="color: #800080;">10</span><span style="color: #000000;">; 

</span><span style="color: #0000ff;">return</span> <span style="color: #800080;">0</span><span style="color: #000000;">;

}

复制代码

执行./main, 生成的core文件如下所示

GDB调试core文件,查看程序挂在位置。当core dump 之后,使用命令 gdb program core 来查看 core 文件,其中 program 为可执行程序名,core 为生成的 core 文件名。

4、参考资料

http://www.cnblogs.com/hazir/p/linxu_core_dump.html

http://www.cnblogs.com/niocai/archive/2012/04/01/2428128.html

http://baidutech.blog.51cto.com/4114344/904419/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值