• Linux core dump 诊断进程奔溃退出


           最近项目中出现了一个问题,服务器端程序会突然崩溃退出,我们采取了coredump技术以找到崩溃原因,即确定进程退出时正在执行的函数是哪个,其状态如何。
           如果系统开启了coredump,准确的说如果当前的shell环境开启了coredump,当前shell环境下的程序崩溃退出时,会把当时进程的栈的内存状态写入core文件。使用gdb可以查看这个core文件中保存的栈的状态,gdb a.out core。(关于coredump的开启和对shell的理解,请参考本人另一篇博客《由coredump的开启引起的对shell的深入探究》,关于gdb请参考《GDB观察栈的内存布局》)
           core文件生成的位置默认是可执行文件所在的位置,名称默认为core,其位置和名称是可以设置的,我的设置为:
                                                                                                mkdir /home/corefile
    echo “/home/corefile/core-%e-%p-%t” > /proc/sys/kernel/core_pattern
           这样,生成的core文件会放在/home/corefile目录下,core文件名会以core-%e-%p-%t的形式出现,其中%e表示可执行文件的名称,%p表示进程,%t表示生成core文件的时间(注意是unix时间)。
           下面是一个可以导致coredump的例程:

    #include<stdio.h>
    int square(inta, int b){
        int ret;
        int *p = NULL;
        *p = 666;
        return ret;
    }
    int doCalc(intnum1, int num2){
        int ret = square(num1, num2);
        return ret;
    }
    int main(){
        int param1 = 1;
        int param2 = 2;
        int result = doCalc(param1, param2);
        printf("result is %d ",result);
    }

           划线处是会导致coredump处。执行后会在/home/corefile目录下产生以下文件:
    [root@localhostwin7]# ls /home/corefile/
     
     
     
     
    core-a.out-5082-1490760381
     
     
     
     
    a.out是可执行文件名,5082是PID,1490760381是产生该文件的unix时间。把a.out 和core文件放在一个目录下,使用命令:
    gdb  a.out  core-a.out-5082-1490760381
    进入gdb,然后使用backtrace命令,即可看进程退出时的栈的内存状态,如下所示:

    (gdb) bt
    #0  0x00000000004005ba in square(a=1, b=2) at gdbtest.cpp:7
    #1  0x00000000004005e2 in doCalc(num1=1, num2=2) at gdbtest.cpp:12
    #2 0x000000000040060f in main () at gdbtest.cpp:19

           可见,进程退出时,执行的最后一个函数是square函数。
    ---------------------
    作者:yunlong32
    来源:CSDN
    原文:https://blog.csdn.net/u014585564/article/details/68063269
    版权声明:本文为博主原创文章,转载请附上博文链接!
  • 相关阅读:
    bootstrap的portlet组件框框的应用 (点击可伸缩)
    jQuery.trim() 函数及trim()用法详解
    针对谷歌浏览器Chrome的CSS hack
    CSS-如何禁用a标签
    textarea中文本前总是空2格,写入数据库也是
    JNI编程实现(Windows)
    JNI编程实现(Linux)
    FastDFS安装步骤
    iOS离屏渲染之优化分析
    Nginx入门案例(Mac版)
  • 原文地址:https://www.cnblogs.com/xibuhaohao/p/11060200.html
Copyright © 2020-2023  润新知