Linux下怎样使用core文件查看异常崩溃的程序问题

之前在写程序的时候,遇到了意外崩溃的问题,但是当时并没有生成core文件,想用gdb 对程序进行单步跟踪时,并不能复现。所以想要用core文件看看到底是哪里的问题,这里把问题记录下来当再次遇到时可以解决。

Linux CentOS 7生成core dump文件

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

你可能感兴趣的:(Liunx,linux,运维,服务器)