core dump 文件对付诊断linux中措施的问题很是有用。当措施异常退出的时候,大概会生成core文件。如,新加坡电信服务器 马来西亚服务器,措施写一个不属于他的内存,操纵系统出于掩护,会发信号给措施,措施大概会因此而退出,退出的时候大概会生成core文件。我们可以通过阐明core文件,找出措施中哪里有内存问题。这篇文章主要是叙述生成core文件需要做的一些配置。
如何生成core文件
默认linux操纵系统是不答允生成core文件的。如下图:
我们可以通过如下呼吁清除限制:
#ulimit -c unlimited
这时候,再看
留意,ulimit -c
的配置仅仅是对你完成配置后启动的历程有效。并且退出登岸后,再进入需要重新配置。不然重新登岸后启动的历程也无法生成core文件。
假如想永久生效,可以把呼吁插手到 /etc/profile 中。发起不要这样做,想想为啥?
如何找到core文件
一般环境下,core文件会生成在你执行措施的处所。文件名是core.历程号
你也可以指定core文件名和生成目次。在 /etc/sysctl.conf 文件中指定。
添加如下行:
kernel.core_uses_pid = 1
kernel.core_pattern = /tmp/core-%e-%s-%u-%g-%p-%t
fs.suid_dumpable = 2
kernel.core_uses_pid = 1 – 追加历程号到core文件名中
fs.suid_dumpable = 2 – 确保配置属主的历程也可以生成core文件
kernel.core_pattern = /tmp/core-%e-%s-%u-%g-%p-%t –
指定core文件生成的位置和文件名法则。文件名法则可以利用的参数有:
%% – 标记%
%p – 历程号
%u – 历程用户id
%g – 历程用户组id
%s – 生成core文件时收到的信号
%t – 生成core文件的 时间 (seconds since 0:00h, 1 Jan 1970)
%h – 主机名
%e – 措施文件名
执行如下呼吁,让配置生效
#sysctl -p除此之外,也可以通过如下方法指定core文件名和路径
$echo /tmp/core-%e-%s-%u-%g-%p-%t > /proc/sys/kernel/core_pattern
如何利用core文件
可以利用gdb呼吁查察core文件信息
$ gdb -e /path/to/application -c /path/to/corefile
假如有任何疑问,请加作者微博相同。