【转】https://blog.csdn.net/xuan_xuan_2/article/details/107145368?utm_medium=distribute.pc_relevant.none-task-blog-baidujs_title-1&spm=1001.2101.3001.4242
Linux环境下进程发生异常而挂掉,通常很难查找原因,但是一般Linux内核给我们提供的核心文件,记录了进程在崩溃时候的信息。但是生成core文件需要设置开关,具体步骤如下:
1、查看生成core文件的开关是否开启,输入命令# ulimit -a
第一行core文件大小为0,表示没有开启。
2、使用#ulimit -c [kbytes]可以设置系统允许生成的core文件大小(临时生效);
ulimit -c 0 不产生core文件
ulimit -c 100 设置core文件最大为100k
ulimit -c unlimited 不限制core文件大小
执行命令# ulimit -c unlimited,然后ulimit -a查看core
3、永久生效的方法
#vim /etc/profile,然后进入编辑模式,在profile文件中加入
ulimit -c unlimited
保存退出,重启服务器,改文件就长久生效,或者#source /etc/profile,不重启服务器,使用source使文件马上生效。
指定生成文件的路径和名字;执行# vim /etc/sysctl.conf,进入编辑模式,加入下面两行
kernel.core_pattern=/var/corefile/core_%e_%p
kernel.core_uses_pid=0
# sysctl -p /etc/sysctl.conf,是修改马上生效。
core_pattern的命名参数如下:
%c 转储文件的大小上限 %e 所dump的文件名 %g 所dump的进程的实际组ID %h 主机名 %p 所dump的进程PID %s 导致本次coredump的信号 %t 转储时刻(由1970年1月1日起计的秒数) %u 所dump进程的实际用户ID
4、# kill -s SIGSEGV $$ ,执行命令,可以看到/tmp/corefile下生成了一个core文件,说明已经设置成功。