Linux core dump 生成和除錯
core dump
某些訊號的產生會導致產生core dump,包含了程序終止時的記憶體映象。在某些時候這個core檔案就非常的有用處,配合gdb或者lldb除錯起來非常方便。
更詳細的文件參考 Linux Manual Page http://man7.org/linux/man-pages/man5/core.5.html.
生成 core 檔案
這裡只講生成的方法,不能生成core的情況參考文件
ulimit -c -H 為檢視core資源的命令 -c 為軟資源限制(作業系統分配),-H 為作業系統資源的上限。
-
命令
ulimit -c LIMIT
,LIMIT
為設定的core檔案的大小,也可以設定為unlimited
,當退出當前tty後設置便失效,資源限制成 0 -
修改
/etc/profile
,增加ulimit -c LIMIT
,同上 -
修改
/etc/security/limits.conf
, 將 core 對應的 value 修改為要設定的值 -
呼叫函式
setrlimit()
設定當前程序的軟core資源限制
struct rlimit rlim;
rlim.rlim_cur = 1024 * 1024;
// rlim.rlim_max 不設定
setrlimit(RLIMIT_CORE, &rlim);
除錯
1 // File: lim.c
2 // Author: xianhui ([email protected])
3 // Date: 2018/09/10 15:24:07
4
5 #include <sys/resource.h>
6 #include <unistd.h>
7 #include <stdio.h>
8 #include <limits.h>
9
10 int main()
11 {
12 struct rlimit rlim;
13
14 getrlimit(RLIMIT_CORE, &rlim);
15 printf("cur: %lu, max: %lu\n", rlim.rlim_cur, rlim.rlim_max);
16
17 rlim.rlim_cur = 1024 * 1024;
18 // rlim.rlim_max 不設定
19
20 setrlimit(RLIMIT_CORE, &rlim);
21
22 getrlimit(RLIMIT_CORE, &rlim);
23 printf("cur: %lu, max: %lu\n", rlim.rlim_cur, rlim.rlim_max);
24
25 int *ptr = NULL;
26 for (int i = 0; i < 20; i++)
27 if (i == 10)
28 *ptr = 12;
29 }
// 顯然在第28行是錯誤的,這個用肉眼也能看的出來,但是如果是一個比較大的程式,就只顧首不顧尾了,有這個檔案在,配合lldb
lldb a.out --core core_p20828_s11_t1536568024
·
·
·
Process 21168 stopped
* thread #1: tid = 21168, 0x0000000000400679 a.out`main + 169 at lim.c:28,name = 'a.out', stop reason = signal SIGSEGV: invalid address (faultaddress: 0x0)
frame #0: 0x0000000000400679 a.out`main + 169 at lim.c:28
25 int *ptr = NULL;
26 for (int i = 0; i < 20; i++)
27 if (i == 10)
-> 28 *ptr = 12;
29 }
// 直接定位到段錯誤的地方,這個刻意 i == 10 的時候才出的錯,是為了監視i的值
(lldb) p i
(int) $0 = 10
// 監視段錯誤的時候 rlim.cur 的值
(lldb) p rlim.rlim_cur
(rlim_t) $1 = 1048576
具體的core檔案生成限制,core檔名的顯示,控制將哪些對映寫入核心轉儲 等說明參考manual page。
其實說白了,就是一個核心分配生成core檔案大小和將記憶體映像寫入至那個檔案中的操作。
剛開始這個core始終不能生成,是應為我抄了manual page中的那個示例,但是示例產生檔案目錄名和我當時的目錄不一致,這就導致了core不能生成。
當前我的/proc/sys/kernel/core_pattern檔案內容為core_p%p_s%s_t%t,產生的檔案為core_p20828_s11_t1536568024
Linux公社的RSS地址:ofollow,noindex" target="_blank">https://www.linuxidc.com/rssFeed.aspx
本文永久更新連結地址:https://www.linuxidc.com/Linux/2018-09/154034.htm