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
假如有任何疑問,請加作者微博相同。