Linux Core Dump 是一个包含程序运行时内存信息的文件,当程序崩溃时生成
-
确认 Core Dump 是否已生成: 通常情况下,Core Dump 文件会在程序崩溃时生成在当前工作目录或者系统默认的目录(如 /var/lib/systemd/coredump/)。你可以使用
ls
命令查看当前目录下是否有 core 文件。如果没有,请检查系统配置是否允许生成 Core Dump。 -
开启 Core Dump: 如果系统禁止了 Core Dump 生成,你需要修改
/proc/sys/kernel/core_pattern
文件来设置允许生成 Core Dump。例如,你可以使用以下命令将 Core Dump 文件生成在当前工作目录:echo 'core' | sudo tee /proc/sys/kernel/core_pattern
-
设置 Core Dump 文件大小限制: 使用
ulimit -c
命令设置 Core Dump 文件大小限制。例如,设置 Core Dump 文件大小限制为无限制,可以使用以下命令:ulimit -c unlimited
-
使用 gdb 分析 Core Dump: gdb(GNU Debugger)是一个功能强大的调试工具,可以用来分析 Core Dump 文件。首先安装 gdb(如果尚未安装):
sudo apt-get install gdb
然后,使用 gdb 打开 Core Dump 文件并进行调试:
gdb <程序名>
接下来,你可以在 gdb 中使用各种命令来查看堆栈跟踪、变量值等信息,以帮助定位问题。
-
分析 gdb 输出: 在 gdb 中,你可以使用以下命令来查看更多信息:
bt
:显示当前线程的堆栈跟踪。thread apply all bt
:显示所有线程的堆栈跟踪。info threads
:显示当前程序的所有线程。frame
:选择指定帧并显示相关信息。list <函数名>
:显示指定函数的源代码。print <变量名>
:显示指定变量的值。
通过以上步骤,你可以分析 Linux Core Dump 文件,找到程序崩溃的原因并修复问题。