Linux 无法生成core dump文件解决方法及core查看
检查Linux 无法产生Coredump文件是因为用户所拥有的进程没有对应coredump文件写入权限。修改文件目录即可。 (1)首先确保,在 /etc/profile 中添加了ulimit -c unlimited保证开启coredump;(2)修改sudo v...
检查
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
更多推荐
所有评论(0)