Linux 无法生成core dump文件解决方法及core查看

本文介绍了如何在Linux系统中配置coredump,并使用GDB进行程序调试。首先,通过`ulimit -c unlimited`确保开启coredump,接着在`/etc/sysctl.conf`中设置coredump文件路径和格式。然后,执行`sysctl -p /etc/sysctl.conf`使配置生效。测试过程中,发送`SIGSEGV`信号给进程以触发coredump。在生成的core文件中,使用GDB进行调试,通过`bt`命令查看调用堆栈,定位问题。关键词包括Linux、coredump、GDB、调试、信号处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

检查

Linux 无法产生Coredump文件是因为用户所拥有的进程没有对应coredump文件写入权限。修改文件目录即可。
(1)首先确保,在 /etc/profile 中添加了

 ulimit -c unlimited

保证开启coredump;

(2)修改sudo vi /etc/sysctl.conf, 添加coredump对应目录及格式,此处user为你的用户名对应目录,别忘记创建这个/home/user/coredump文件夹:

/home/user/coredump/core.%e.%p.%s.%E

%e 所dump的文件名
%p 所dump的进程PID
%s 导致本次coredump的信号
%E 进程执行所在目录
%c 转储文件的大小上限
%g 所dump的进程的实际组ID
%h 主机名
%t 转储时刻(由1970年1月1日起计的秒数)
%u 所dump进程的实际用户ID
(3)最后,输入以下命令即刻生效

sudo sysctl -p /etc/sysctl.conf

(4) 测试,输入以下命令,然后会关闭shell

kill -s SIGSEGV $$

(5)查看/home/user/coredump文件夹下是否存在core文件;

gdb查看

格式如下:
gdb [exec file] [core file]

#include<stdio.h>
int main(){
  int *a = NULL;
  *a = 0;
}

编译运行

gcc test.c -o test
./test

产生Segmentation fault (core dumped),调试

gdb  ./test  /home/user/coredump/your_dump_file
Program terminated with signal SIGSEGV, Segmentation fault.
#0  0x0000000000400546 in main ()
# 输入bt查看问题
(gdb) bt
#0  0x0000000000400546 in main ()

比如以上信息表示在main()函数中出现问题
有时候bt后显现出来的是No stack. 这种问题应该是编译时优化导致。

其他常用选项有:
l(list) ,显示源代码,并且可以看到对应的行号;
b(break)x, x是行号,表示在对应的行号位置设置断点;
p(print)x, x是变量名,表示打印变量x的值
r(run), 表示继续执行到断点的位置
n(next),表示执行下一步
c(continue),表示继续执行
q(quit),表示退出gdb

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值