检查

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

Logo

更多推荐