linux下core dump--转载
原文鏈接:https://www.cnblogs.com/Anker/p/6079580.html
1、前言
一直在從事linux下后臺開發(fā),經(jīng)常與core文件打交道。還記得剛開始從事linux下開發(fā)時,程序突然崩潰了,也沒有任何日志。我不知所措,同事叫我看看core,我卻問什么是core,怎么看。同事鄙視的眼神,我依然在目。后來學會了從core文件中分析原因,通過gdb看出程序掛再哪里,分析前后的變量,找出問題的原因。當時就覺得很神奇,core文件是怎么產生的呢?難道系統(tǒng)會自動產生,可是我在自己的linux系統(tǒng)上面寫個非法程序測試,并沒有產生core問題?這又是怎么回事呢?今天在ngnix的源碼時候,發(fā)現(xiàn)可以在程序中設置core dump,又是怎么回事呢?在公司發(fā)現(xiàn)生成的core文件都帶有進程名稱、進程ID、和時間,這又是怎么做到的呢?今天帶著這些疑問來說說core文件是如何生成,如何配置。
2、基本概念
當程序運行的過程中異常終止或崩潰,操作系統(tǒng)會將程序當時的內存狀態(tài)記錄下來,保存在一個文件中,這種行為就叫做Core Dump(中文有的翻譯成“核心轉儲”)。我們可以認為 core dump 是“內存快照”,但實際上,除了內存信息之外,還有些關鍵的程序運行狀態(tài)也會同時 dump 下來,例如寄存器信息(包括程序指針、棧指針等)、內存管理信息、其他處理器和操作系統(tǒng)狀態(tài)和信息。core dump 對于編程人員診斷和調試程序是非常有幫助的,因為對于有些程序錯誤是很難重現(xiàn)的,例如指針異常,而 core dump 文件可以再現(xiàn)程序出錯時的情景。
3、開啟core dump
可以使用命令ulimit開啟,也可以在程序中通過setrlimit系統(tǒng)調用開啟。
程序中開啟core dump,通過如下API可以查看和設置RLIMIT_CORE
#include <sys/resource.h>int getrlimit(int resource, struct rlimit *rlim); int setrlimit(int resource, const struct rlimit *rlim);參考程序如下所示:
#include <unistd.h> #include <sys/time.h> #include <sys/resource.h> #include <stdio.h> #define CORE_SIZE 1024 * 1024 * 500 int main() {struct rlimit rlmt;if (getrlimit(RLIMIT_CORE, &rlmt) == -1) {return -1; } printf("Before set rlimit CORE dump current is:%d, max is:%d\n", (int)rlmt.rlim_cur, (int)rlmt.rlim_max);rlmt.rlim_cur = (rlim_t)CORE_SIZE;rlmt.rlim_max = (rlim_t)CORE_SIZE;if (setrlimit(RLIMIT_CORE, &rlmt) == -1) {return -1; } if (getrlimit(RLIMIT_CORE, &rlmt) == -1) {return -1; } printf("After set rlimit CORE dump current is:%d, max is:%d\n", (int)rlmt.rlim_cur, (int)rlmt.rlim_max);/*測試非法內存,產生core文件*/int *ptr = NULL;*ptr = 10; return 0; }執(zhí)行./main, 生成的core文件如下所示
GDB調試core文件,查看程序掛在位置。當core dump 之后,使用命令?gdb program core?來查看 core 文件,其中 program 為可執(zhí)行程序名,core 為生成的 core 文件名。
4、參考資料
http://www.cnblogs.com/hazir/p/linxu_core_dump.html
http://www.cnblogs.com/niocai/archive/2012/04/01/2428128.html
http://baidutech.blog.51cto.com/4114344/904419/
轉載于:https://www.cnblogs.com/xibuhaohao/p/11057834.html
《新程序員》:云原生和全面數(shù)字化實踐50位技術專家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結
以上是生活随笔為你收集整理的linux下core dump--转载的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Webpack介绍和使用(配置环境变量,
- 下一篇: AgileEAS.NET平台视频会议培训