linux dump 不影响原进程,Linux下利用coredump技术追查进程崩溃缘由

原文连接:https://blog.csdn.net/u014585564/article/details/68063269 shell

最近项目中出现了一个问题,服务器端程序会忽然崩溃退出,咱们采起了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的例程:

036f51f065d45feb3d51e79d1f05a9cf.png服务器

划线处是会致使coredump处。执行后会在/home/corefile目录下产生如下文件:

[root@localhostwin7]# ls /home/corefile/

8ff2ab766f51c1d0b8c4133d5cd813f8.png函数

a.out是可执行文件名,5082是PID,1490760381是产生该文件的unix时间。把a.out 和core文件放在一个目录下,使用命令:

gdb  a.out  core-a.out-5082-1490760381

进入gdb,而后使用backtrace命令,便可看进程退出时的栈的内存状态,以下所示:

11e787f46ca78b97d80c22f02d8b0657.png布局

可见,进程退出时,执行的最后一个函数是square函数。

————————————————

.net

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值