Linux环境下如何生成core文件

【转】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文件,说明已经设置成功。

原文地址:https://www.cnblogs.com/jzhg/p/14921872.html