婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 淺析Linux下利用coredump技術追查進程崩潰原因

淺析Linux下利用coredump技術追查進程崩潰原因

熱門標簽:400電話干嘛怎么申請信用卡 接電話機器人罵人 長春電銷外呼系統(tǒng)代理商 代理外呼系統(tǒng)創(chuàng)業(yè) 外呼系統(tǒng)虛擬號碼 400電話申請知乎 大連電銷外呼系統(tǒng)運營商 泰州智能外呼系統(tǒng)排名 百度地圖標注尺寸無法顯示

最近項目中出現(xiàn)了一個問題,服務器端程序會突然崩潰退出,我們采取了coredump技術以找到崩潰原因,即確定進程退出時正在執(zhí)行的函數(shù)是哪個,其狀態(tài)如何。

如果系統(tǒng)開啟了coredump,準確的說如果當前的shell環(huán)境開啟了coredump,當前shell環(huán)境下的程序崩潰退出時,會把當時進程的棧的內(nèi)存狀態(tài)寫入core文件。使用gdb可以查看這個core文件中保存的棧的狀態(tài),gdb a.out core。(關于coredump的開啟和對shell的理解,請參考本人另一篇博客《使用dotnet-dump 查找 .net core 3.0 占用CPU 100%的原因解析》,關于gdb請參考《gdb調(diào)試命令的使用及總結》)

core文件生成的位置默認是可執(zhí)行文件所在的位置,名稱默認為core,其位置和名稱是可以設置的,我的設置為:

mkdir /home/corefile 
echo “/home/corefile/core-%e-%p-%t” > /proc/sys/kernel/core_pattern 

這樣,生成的core文件會放在/home/corefile目錄下,core文件名會以core-%e-%p-%t的形式出現(xiàn),其中%e表示可執(zhí)行文件的名稱,%p表示進程,%t表示生成core文件的時間(注意是unix時間)。

下面是一個可以導致coredump的例程:

劃線處是會導致coredump處。執(zhí)行后會在/home/corefile目錄下產(chǎn)生以下文件:

[root@localhostwin7]# ls /home/corefile/

a.out是可執(zhí)行文件名,5082是PID,1490760381是產(chǎn)生該文件的unix時間。把a.out 和core文件放在一個目錄下,使用命令:

gdb a.out core-a.out-5082-1490760381

進入gdb,然后使用backtrace命令,即可看進程退出時的棧的內(nèi)存狀態(tài),如下所示:

可見,進程退出時,執(zhí)行的最后一個函數(shù)是square函數(shù)。 ————————————————

總結

以上所述是小編給大家介紹的Linux下利用coredump技術追查進程崩潰原因,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

標簽:臺灣 清遠 興安盟 長治 雅安 大慶 安陽 中衛(wèi)

巨人網(wǎng)絡通訊聲明:本文標題《淺析Linux下利用coredump技術追查進程崩潰原因》,本文關鍵詞  淺析,Linux,下,利用,coredump,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《淺析Linux下利用coredump技術追查進程崩潰原因》相關的同類信息!
  • 本頁收集關于淺析Linux下利用coredump技術追查進程崩潰原因的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 昌乐县| 华宁县| 甘洛县| 玉环县| 台北县| 东莞市| 大化| 绥宁县| 台东市| 海原县| 新源县| 云和县| 尼玛县| 灌南县| 巴林右旗| 乌鲁木齐县| 绿春县| 浠水县| 阿拉尔市| 合江县| 嘉义县| 萝北县| 洪雅县| 平昌县| 和静县| 山西省| 哈尔滨市| 寻甸| 武乡县| 钟山县| 瑞昌市| 莱西市| 信丰县| 仲巴县| 黎川县| 吉首市| 莆田市| 博罗县| 山东省| 富锦市| 天台县|