core dump 某些信號的產生會導致產生core dump,包含了進程終止時的記憶體鏡像。在某些時候這個core文件就非常的有用處,配合gdb或者lldb調試起來非常方便。 更詳細的文檔參考 Linux Manual Page http://man7.org/linux/man pages/man ...
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