1、查看当前系统是否生成core dump文件
ulimit -c
0:表示当前不生成core dump文件
大于0的数:表示当前生成的core dump文件大小限制在该值以内,单位是Kb。
unlimited:core dump 文件的大小不受限制。
要设置是否生成core dump文件以及大小限制,就是在ulimit -c 后面加上要设置的值或unlimited,比如:
ulimit -c 0
ulimit -c 1024
ulimit -c unlimited
用ulimit命令设置的值是临时性的,如果要永久生效,可以在 /etc/security/limits.conf 文件里修改
在文件中修改后需要重新登录账号才会生效。
2、设置core dump文件的存储位置以及命名规则
该设置存储在 /proc/sys/kernel/core_pattern 文件中
上面截图中的配置表示core dump 文件存储在/data/core目录下,命名为core_<启动命令>_<进程pid>,一些可用的命名参数如下:
%p : insert pid into filename 添加pid
%u :insert current uid into filename 添加当前uid
%g : insert current gid into filename 添加当前gid
%s : insert signal that caused the coredump into the filename 添加导致产生core的信号
%t : insert UNIX time that the coredump occurred into filename 添加core文件生成时的unix时间
%h : insert hostname where the coredump happened into filename 添加主机名
%e : insert coredumping executable name into filename 添加命令名
3、测试core dump
测试使用一段简单的C代码,试图修改字符串常量中的字符,从而触发段错误
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main(int argc, char *argv[])
{
int pid = getpid();
printf("pid = %d\n", pid);
int i = 0;
i++;
char *str = "hello world";
// trigger a segmentation fault
str[0] = 'H';
return 0;
}
编译运行:
可以看到 /data/core 目录下生成了一个名为core_a.out_975的core dump 文件。
4、定位触发core dump的代码位置
gdb [options] [executable-file [core-file or process-id]]
例如:
编译时需要加上 -g 参数。