1. 内核转储作用
(1) 内核转储的最大好处是能够保存问题发生时的状态。
(2) 只要有可执行文件和内核转储,就可以知道进程当时的状态。
(3) 只要获取内核转储,那么即使没有复现环境,也能调试。
centos 6 设置内核转储
统一命令为以下几条命令,后面是解释
echo "* soft core unlimited" >> /etc/security/limits.conf
echo "kernel.core_pattern = /tmp/core-%e-%s-%u-%g-%p-%t" >> /etc/sysctl.conf
echo "fs.suid_dumpable = 2" >> /etc/sysctl.conf
echo "DAEMON_COREFILE_LIMIT=’unlimited’" >> /etc/sysconfig/init
sysctl -p
编辑/etc/security/limits.conf,注意这是为所有进程设置的,但如果你有一个作为服务帐户运行的进程,请用服务帐户替换*。您必须重新启动此过程以使此更改生效。
编辑/etc/sysctl.conf并添加放置核心文件和任何命名标准的位置。
文件名变量:
%e是文件名
%g是进程运行的gid
%p是进程的PID
%s是导致转储的信号
%t是转储发生的时间
%u是进程运行的uid
编辑/etc / sysconfig / init并设置核心文件限制。
centos 7 设置内核转储
echo -e "\n# enable coredump whith unlimited file-size for all users\n* soft core unlimited" >> /etc/security/limits.conf
echo -e "\nkernel.core_pattern=/tmp/core-%e-%s-%u-%g-%p-%t" >> /etc/sysctl.conf
echo -e "1" > /proc/sys/kernel/core_uses_pid
sysctl -p /etc/sysctl.conf
2,测试是否生效
例子的源代码:
#include
int main(void)
{
int *a = NULL;
*a = 0x1;
return 0;
}
把以上源代码,写成一个a.c文件后,编译a.c文件产生一个a.out的可执行文件:
#gcc -g a.c -o a.out
修改a.out文件的权限后,执行它:
#./a.out
就会显示:
Segmentation fault(core dump)
这表示在/tmp目录下, 已经生成了a.out对应的内核转储文件。
注意:后面带有(core dump), 才说明转储文件成功生成了。