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

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值