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
在这里插入图片描述
  这样进程崩溃就可以生成core文件了,这种方法只能在shell中生效,下面说一下永久生效的方法:

#vim /etc/profile,然后进入编辑模式,在profile文件中加入
ulimit -c unlimited
在这里插入图片描述
  保存退出,重启服务器,改文件就长久生效,或者#source /etc/profile,不重启服务器,使用source使文件马上生效。

3.指定生成文件的路径和名字;执行# vim /etc/sysctl.conf,进入编辑模式,加入下面两行

kernel.core_pattern=/tmp/corefile/core_%e_%p
kernel.core_uses_pid=0
在这里插入图片描述
  在var下创建core目录,用# 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文件,说明已经设置成功。
在这里插入图片描述
  现在可以对进程出问题用gdb对core文件调试了,分析问题。

Logo

更多推荐