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