linux系统核心转储文件coredump

coredump功能:

当程序运行的过程中异常终止或崩溃,操作系统会将程序当时的内存状态记录下来,保存在一个文件中,这种行为就叫做Core Dump(中文有的翻译成“核心转储”)。我们可以认为 core dump 是“内存快照”,但实际上,除了内存信息之外,还有些关键的程序运行状态也会同时 dump 下来,例如寄存器信息(包括程序指针、栈指针等)、内存管理信息、其他处理器和操作系统状态和信息。core dump 对于编程人员诊断和调试程序是非常有帮助的,因为对于有些程序错误是很难重现的,例如指针异常,而 core dump 文件可以再现程序出错时的情景。

如何使用:

在终端中输入命令 ulimit -c ,输出的结果为 0,说明默认是关闭 core dump 的,即当程序异常终止时,也不会生成 core dump 文件。

使用命令 ulimit -c unlimited 来开启 core dump 功能,并且不限制 core dump 文件的大小; 如果需要限制文件的大小,将 unlimited 改成你想生成 core 文件最大的大小,注意单位为 blocks(KB)。

修改内核参数 /proc/sys/kernel/core_pattern 来指定生成核心转储文件的路径和格式

echo "/tmp/corefile-%e-%p-%t" > /proc/sys/kernel/core_pattern

表示在/tmp/目录下生成文件,文件名为corefile-%e-%p-%t,其中,e/p/t等分别表示:

  • %e 所dump的文件名
  • %g 所dump的进程的实际组ID
  • %h 主机名
  • %p 所dump的进程PID
  • %s 导致本次coredump的信号
  • %t 转储时刻 (由1970年1月1日起计的秒数)
  • %u 所dump进程的实际用户ID
    如果未指定生成的核心转储文件名称,则默认名称为 core

产生崩溃:在程序运行时,如果发生异常或错误,将会生成一个名为 core 的核心转储文件。该文件记录了程序崩溃时的内存状态、寄存器值等信息,可以作为分析崩溃原因的关键信息。请注意,如果设置了核心转储文件大小限制,核心转储文件可能不会被生成。

  • RK平台这里遇到个问题:launcher进程崩溃了,但是没有生成core文件
  • 板子上只有/userdata目录可写
$ mkdir /userdata/coredumps    # 创建用于存储核心转储文件的目录
$ sysctl -w fs.suid_dumpable=2 # 设置允许任何用户生成核心转储文件
$ echo "/userdata/coredumps/core" > /proc/sys/kernel/core_pattern  # 设置核心转储文件路径

分析 coredump:使用调试工具(如 gdb)加载生成的 coredump 文件进行分析。

  • 在终端中输入以下命令(假设 coredump 文件名为 “core”):gdb <可执行文件> core
  • 启动 gdb 并加载 coredump 文件。你可以使用 gdb 提供的命令和调试功能来分析崩溃现场。
  • 使用 bt(backtrace)命令可以打印出崩溃时的函数调用栈,info registers 命令可以查看寄存器状态等
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值