麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 服務(wù)器 > Linux服務(wù)器 > 正文

關(guān)于linux下core dump【總結(jié)】

2024-09-05 23:03:29
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

1、前言

一直在從事linux下后臺(tái)開(kāi)發(fā),經(jīng)常與core文件打交道。還記得剛開(kāi)始從事linux下開(kāi)發(fā)時(shí),程序突然崩潰了,也沒(méi)有任何日志。我不知所措,同事叫我看看core,我卻問(wèn)什么是core,怎么看。同事鄙視的眼神,我依然在目。后來(lái)學(xué)會(huì)了從core文件中分析原因,通過(guò)gdb看出程序掛再哪里,分析前后的變量,找出問(wèn)題的原因。當(dāng)時(shí)就覺(jué)得很神奇,core文件是怎么產(chǎn)生的呢?難道系統(tǒng)會(huì)自動(dòng)產(chǎn)生,可是我在自己的linux系統(tǒng)上面寫個(gè)非法程序測(cè)試,并沒(méi)有產(chǎn)生core問(wèn)題?這又是怎么回事呢?今天在ngnix的源碼時(shí)候,發(fā)現(xiàn)可以在程序中設(shè)置core dump,又是怎么回事呢?在公司發(fā)現(xiàn)生成的core文件都帶有進(jìn)程名稱、進(jìn)程ID、和時(shí)間,這又是怎么做到的呢?今天帶著這些疑問(wèn)來(lái)說(shuō)說(shuō)core文件是如何生成,如何配置。

2、基本概念

當(dāng)程序運(yùn)行的過(guò)程中異常終止或崩潰,操作系統(tǒng)會(huì)將程序當(dāng)時(shí)的內(nèi)存狀態(tài)記錄下來(lái),保存在一個(gè)文件中,這種行為就叫做Core Dump(中文有的翻譯成“核心轉(zhuǎn)儲(chǔ)”)。我們可以認(rèn)為 core dump 是“內(nèi)存快照”,但實(shí)際上,除了內(nèi)存信息之外,還有些關(guān)鍵的程序運(yùn)行狀態(tài)也會(huì)同時(shí) dump 下來(lái),例如寄存器信息(包括程序指針、棧指針等)、內(nèi)存管理信息、其他處理器和操作系統(tǒng)狀態(tài)和信息。core dump 對(duì)于編程人員診斷和調(diào)試程序是非常有幫助的,因?yàn)閷?duì)于有些程序錯(cuò)誤是很難重現(xiàn)的,例如指針異常,而 core dump 文件可以再現(xiàn)程序出錯(cuò)時(shí)的情景。

3、開(kāi)啟core dump

可以使用命令ulimit開(kāi)啟,也可以在程序中通過(guò)setrlimit系統(tǒng)調(diào)用開(kāi)啟。

linux,core,dump

 

 

 

程序中開(kāi)啟core dump,通過(guò)如下API可以查看和設(shè)置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 * 500int 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);  /*測(cè)試非法內(nèi)存,產(chǎn)生core文件*/  int *ptr = NULL;  *ptr = 10;   return 0;}

執(zhí)行./main, 生成的core文件如下所示

linux,core,dump

GDB調(diào)試core文件,查看程序掛在位置。當(dāng)core dump 之后,使用命令 gdb program core 來(lái)查看 core 文件,其中 program 為可執(zhí)行程序名,core 為生成的 core 文件名。

linux,core,dump

以上這篇關(guān)于linux下core dump【總結(jié)】就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持VEVB武林網(wǎng)。

 

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 一边吃奶一边摸下娇喘 | 成人男男视频拍拍拍在线观看 | 国产精品99爱 | 91精品国产九九九久久久亚洲 | 中文字幕国产亚洲 | 欧美一级高潮 | 黄色免费入口 | 黄色特级毛片 | 人禽l交免费视频观看 视频 | 久久久三区 | 一级免费看片 | 国产做爰 | 精品中文视频 | 欧美亚洲国产成人综合在线 | 日韩视频在线一区二区三区 | 亚洲影视中文字幕 | 一级黄片毛片免费看 | 久久手机在线视频 | 老司机免费福利午夜入口ae58 | 国产午夜精品久久久久婷 | caoporn国产一区二区 | 午夜视频大全 | av电影在线网站 | 精品久久久久久久久亚洲 | 亚洲啪| www.99热视频 | 美女亚洲综合 | 免费放黄网站在线播放 | 久久色在线 | 久久久一区二区精品 | 亚洲欧美aⅴ| 欧美日韩视频网站 | h色在线观看 | 成人午夜一区二区 | 精品一区二区在线观看 | 欧美亚洲国产日韩 | 全黄性性激高免费视频 | 国产精品视频久 | 亚洲成人精品一区二区 | 国产成人精品无人区一区 | 最新在线黄色网址 |