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
如果有任何疑問,請加作者微博溝通。