Linux中如何產生core文件?

 
  在程序不尋常退出時,內核會在當前工做目錄下生成一個core文件(是一個內存映像,同時加上調試信息)。使用gdb來查看core文件,能夠指示出致使程序出錯的代碼所在文件和行數。
 

1.core文件的生成開關和大小限制

 
  (1)使用ulimit -c命令可查看core文件的生成開關。若結果爲0,則表示關閉了此功能,不會生成core文件。 
  (2)使用ulimit -c filesize命令,能夠限制core文件的大小(filesize的單位爲kbyte)。例如使用ulimit -c 1000將會把core文件限制爲1000KB。若是生成的信息超過此大小,將會被裁剪,最終生成一個不完整的core文件,在調試此core文件的時候,gdb會提示錯誤。
  (3)使用ulimit -c unlimited,則表示core文件的大小不受限制。 
  (4)能夠將ulimit -c unlimited寫入到.bashrc中。 
 

2.core文件生成路徑

 
  默認爲輸入可執行文件運行命令的同一路徑下。若系統生成的core文件不帶其它任何擴展名稱,則所有命名爲core。新的core文件生成將覆蓋原來的core文件。
  如何查詢和修改Linux操做系統生成core dump文件的默認路徑? 
  方法1:cat /proc/sys/kernel/core_pattern 
  方法2:/sbin/sysctl kernel.core_pattern 

  

3.控制core文件的文件名中是否添加pid做爲擴展 

 
  這個文件/proc/sys/kernel/core_uses_pid能夠控制core文件的文件名中是否添加pid做爲擴展。文件內容爲1,表示添加 pid做爲擴展名,生成的core文件格式爲core.xxxx;爲0則表示生成的core文件同一命名爲core。可經過如下命令修改此文件:echo "1" > /proc/sys/kernel/core_uses_pid
 

4.修改core dump文件保存路徑和文件名格式 

 
  方法1:臨時修改:修改/proc/sys/kernel/core_pattern文件,但/proc目錄自己是動態加載的,每次系統重啓都會從新加載,所以這種方法只能做爲臨時修改。
  echo "/corefile/core-%e-%p-%t" > /proc/sys/kernel/core_pattern,能夠將core文件統一輩子成到/corefile目錄下,產生的文件名爲core-命令名-pid-時間戳
 
  方法2:永久修改:使用sysctl -w name=value命令。 
  /sbin/sysctl -w kernel.core_pattern=/corefile/core-%e-%p-%t 

 

5.爲了更詳盡的記錄core dump當時的系統狀態,可經過如下參數來豐富core文件的命名 

%% - 單個%字符  
%p - insert pid into filename 添加pid 
%u - insert current uid into filename 添加當前uid  
%g - insert current gid into filename 添加當前gid 
%s - insert signal that caused the coredump into the filename 添加致使產生core的信號  
%t - insert UNIX time that the coredump occurred into filename 添加core文件生成時的unix時間(由1970年1月1日計起的秒數)
%h - insert hostname where the coredump happened into filename 添加主機名 
%e - insert coredumping executable name into filename 添加命令名(程序文件名) 

 

6.運行示例

kk@ubuntu:~/Desk/python/day5-27$ echo "1" > /proc/sys/kernel/core_uses_pid 
bash: /proc/sys/kernel/core_uses_pid: 權限不夠 
kk@ubuntu:~/Desk/python/day5-27$ su 
密碼:  
root@ubuntu:/home/kk/Desk/python/day5-27# echo "1" > /proc/sys/kernel/core_uses_pid
root@ubuntu:/home/kk/Desk/python/day5-27# cd /proc/sys/kernel/ 
root@ubuntu:/proc/sys/kernel# echo "/tmp/core-%e-%p-%t" > core_pattern 
root@ubuntu:/proc/sys/kernel# cd - 
/home/kk/Desk/python/day5-27 
root@ubuntu:/home/kk/Desk/python/day5-27# exit 
exit 
kk@ubuntu:~/Desk/python/day5-27$ ll /tmp/         
kk@ubuntu:~/Desk/python/day5-27$ ll /tmp/core-a.out-3173-1401287037  
-rw------- 1 kk kk 413696  5月 28 22:23 /tmp/core-a.out-3173-1401287037 
kk@ubuntu:~/Desk/python/day5-27$ gdb ./a.out /tmp/ 
/tmp/at-spi2                     /tmp/ssh-UTCTvudG1989 
/tmp/core-a.out-3173-1401287037  /tmp/unity_support_test.1 
/tmp/ibus.log                    /tmp/VMwareDnD 
/tmp/.ICE-unix                   /tmp/vmware-kk 
/tmp/keyring-q0k3an              /tmp/vmware-root 
/tmp/pulse-2L9K88eMlGn7          /tmp/.X0-lock 
/tmp/pulse-PKdhtXMmr18n          /tmp/.X11-unix 
/tmp/pulse-Y400HBNSM00c           
kk@ubuntu:~/Desk/python/day5-27$ gdb ./a.out /tmp/core-a.out-3173-1401287037 
相關文章
相關標籤/搜索