Linux上开启core dump

  • Core dump(核心转储)是在程序崩溃时生成的一种文件,其中包含了程序在崩溃时的内存状态信息。它可以帮助程序员在调试程序时快速定位问题,并且是一种非常有用的调试工具。
  • core dump的作用如下:
    • 帮助调试崩溃问题:当程序崩溃时,生成的 core dump 文件可以帮助程序员快速定位问题,因为它包含了崩溃时的内存状态信息,包括变量值、函数调用栈等等。
    • 分析内存泄漏:core dump 文件可以用来检查内存泄漏,因为它包含了程序在崩溃时的内存状态信息,可以分析哪些内存没有被释放。
    • 帮助复现问题:有时候程序崩溃是难以复现的,生成 core dump 可以帮助程序员在不同的环境中重现问题,以便更好地调试。
    • 支持故障排除:当程序出现故障时,生成 core dump 可以帮助程序员快速找到问题的原因,以便更快地解决问题。
  • 检查core dump配置
ulimit -a

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-sNnOVc09-1684328602299)(D:\学习\学习笔记\图片\114.png)]

其中,core file size 指定了 core dump 文件的最大大小,core dump file name 指定了 core dump 文件的名称模板,unlimited 表示不限制。

  • 设置 core dump 文件的最大大小
ulimit -c unlimited

如果系统默认的 core dump 文件大小不够大,可以设置core dump的大小,这将设置 core dump 文件的最大大小为无限制。

  • 检查系统的 core dump 配置是否生效
ulimit -a

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-eg06RHmQ-1684328602301)(D:\学习\学习笔记\图片\115.png)]

  • 设置 core dump 文件保存路径和文件名
sudo sh -c 'echo "/data/logs/core/core.%e.%p.%t" > /proc/sys/kernel/core_pattern'

/data/logs/core/ 是 core dump 文件的保存路径;core.%e.%p.%t是保存的文件名。

  • 开启core dump
echo '1' > /proc/sys/kernel/core_uses_pid

echo '1' > /proc/sys/fs/suid_dumpable
  • 测试 core dump 配置

可以编写一个简单的 C 语言程序,让它崩溃并生成 core dump 文件。以下是一个示例程序:

#include <stdio.h>
#include <stdlib.h>
#include <signal.h>

void signal_handler(int sig) {
    printf("Received signal %d\n", sig);
    abort();
}

int main(int argc, char *argv[]) {
    signal(SIGSEGV, signal_handler);
    char *ptr = NULL;
    *ptr = 'a';
    return 0;
}

编译程序:

gcc -g -o test test.c

运行程序,生成core_dump

./test
  • 分析 core dump 文件
gdb test /path/to/core/dumps/<core dump file>
./test
  • 分析 core dump 文件
gdb test /path/to/core/dumps/<core dump file>

test 是程序的可执行文件,/path/to/core/dumps/<core dump file> 是生成的 core dump 文件。使用 gdb 工具可以分析 core dump 文件,查看程序崩溃的原因。

Logo

更多推荐