之前在写程序的时候,遇到了意外崩溃的问题,但是当时并没有生成core文件,想用gdb 对程序进行单步跟踪时,并不能复现。所以想要用core文件看看到底是哪里的问题,这里把问题记录下来当再次遇到时可以解决。
1.先查看core文件是否开启,查看命令
ulimit -a
或者
ulimit -c
如果 显示 core file size 等于 0,表示没有设置
可以使用以下命令设定生成的core文件大小
ulimit -c 1000 // 设定core文件为1000K
ulimit -c unlimited // 不限制core文件大小
因为内部调试,选择不限制文件大小
在 /etc/profile
或者~/.bashrc
文件中添加以下内容, 这样机器重启,也会生效
ulimit -c unlimited
如果需要立即生效,输入以下命令
source /etc/profile
如果是修改的~/.bashrc
,只需要重新登录用户或者执行source ~/.bashrc
即可。
以上设定完成,就可以生产core dump文件,但是core文件只会在执行程序的目录下。
为了方便查找,可以进行以下设定
core_pattern的命名参数如下:
%c 转储文件的大小上限
%e 所dump的文件名
%g 所dump的进程的实际组ID
%h 主机名
%p 所dump的进程PID
%s 导致本次coredump的信号
%t 转储时刻(由1970年1月1日起计的秒数)
%u 所dump进程的实际用户ID
打开文件 /etc/sysctl.conf
添加以下内容:
kernel.core_pattern=/var/core/core_%e_%p
kernel.core_uses_pid=0
生成的core文件名格式是:core_进程名_进程PID
使用以下命令,生成的core文件就可以统一在/var/core/ 文件夹中查看到了
// 即时生效
sysctl –p /etc/sysctl.conf
备注: /var/ 下 创建新文件夹 core
生成core文件后, 使用gdb调试
gdb /执行程序目录/执行程序 /var/core/core_执行程序名_执行程序PID
分享一个有趣的 学习链接:https://xxetb.xet.tech/s/HY8za