淺析Linux下利用coredump技術(shù)追查進(jìn)程崩潰原因
最近項(xiàng)目中出現(xiàn)了一個(gè)問(wèn)題,服務(wù)器端程序會(huì)突然崩潰退出,我們采取了coredump技術(shù)以找到崩潰原因,即確定進(jìn)程退出時(shí)正在執(zhí)行的函數(shù)是哪個(gè),其狀態(tài)如何。
如果系統(tǒng)開(kāi)啟了coredump,準(zhǔn)確的說(shuō)如果當(dāng)前的shell環(huán)境開(kāi)啟了coredump,當(dāng)前shell環(huán)境下的程序崩潰退出時(shí),會(huì)把當(dāng)時(shí)進(jìn)程的棧的內(nèi)存狀態(tài)寫入core文件。使用gdb可以查看這個(gè)core文件中保存的棧的狀態(tài),gdb a.out core。(關(guān)于coredump的開(kāi)啟和對(duì)shell的理解,請(qǐng)參考本人另一篇博客《使用dotnet-dump 查找 .net core 3.0 占用CPU 100%的原因解析》,關(guān)于gdb請(qǐng)參考《gdb調(diào)試命令的使用及總結(jié)》)
core文件生成的位置默認(rèn)是可執(zhí)行文件所在的位置,名稱默認(rèn)為core,其位置和名稱是可以設(shè)置的,我的設(shè)置為:
mkdir /home/corefile echo “/home/corefile/core-%e-%p-%t” > /proc/sys/kernel/core_pattern
這樣,生成的core文件會(huì)放在/home/corefile目錄下,core文件名會(huì)以core-%e-%p-%t的形式出現(xiàn),其中%e表示可執(zhí)行文件的名稱,%p表示進(jìn)程,%t表示生成core文件的時(shí)間(注意是unix時(shí)間)。
下面是一個(gè)可以導(dǎo)致coredump的例程:
劃線處是會(huì)導(dǎo)致coredump處。執(zhí)行后會(huì)在/home/corefile目錄下產(chǎn)生以下文件:
[root@localhostwin7]# ls /home/corefile/
a.out是可執(zhí)行文件名,5082是PID,1490760381是產(chǎn)生該文件的unix時(shí)間。把a(bǔ).out 和core文件放在一個(gè)目錄下,使用命令:
gdb a.out core-a.out-5082-1490760381
進(jìn)入gdb,然后使用backtrace命令,即可看進(jìn)程退出時(shí)的棧的內(nèi)存狀態(tài),如下所示:
可見(jiàn),進(jìn)程退出時(shí),執(zhí)行的最后一個(gè)函數(shù)是square函數(shù)。 ————————————————
總結(jié)
以上所述是小編給大家介紹的Linux下利用coredump技術(shù)追查進(jìn)程崩潰原因,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
上一篇:Ubuntu18.04更換國(guó)內(nèi)源的方法示例
欄 目:Linux/apache
下一篇:詳解ubuntu雙系統(tǒng)啟動(dòng)時(shí)卡死解決辦法
本文標(biāo)題:淺析Linux下利用coredump技術(shù)追查進(jìn)程崩潰原因
本文地址:http://www.jygsgssxh.com/a1/Linux_apache/10603.html
您可能感興趣的文章
- 04-02linux關(guān)閉串口命令 關(guān)閉linux端口命令
- 04-02linux文件命令重命名 linux重命名文件名命令
- 04-02linux命令注入過(guò)濾 linux 代碼注入
- 04-02linux中jobs命令 shell jobs命令
- 04-02linux依次執(zhí)行命令 linux命令的執(zhí)行過(guò)程是怎樣的?新手必讀
- 04-02linux命令免輸入 linux配置免密登錄
- 04-02linux命令注銷vnc linux命令行注銷用戶
- 04-02軟交換linux命令 軟交換網(wǎng)絡(luò)主要協(xié)議有哪些
- 04-02linux命令歷史記錄 linux查看歷史記錄的操作命令
- 04-02linux命令頁(yè)面 linux命令頁(yè)面中文


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02linux關(guān)閉串口命令 關(guān)閉linux端口命令
- 04-02linux文件命令重命名 linux重命名文件名
- 04-02linux中jobs命令 shell jobs命令
- 04-02linux命令注入過(guò)濾 linux 代碼注入
- 04-02linux依次執(zhí)行命令 linux命令的執(zhí)行過(guò)程
- 04-02linux命令注銷vnc linux命令行注銷用戶
- 04-02linux命令免輸入 linux配置免密登錄
- 04-02軟交換linux命令 軟交換網(wǎng)絡(luò)主要協(xié)議
- 04-02linux命令歷史記錄 linux查看歷史記錄的
- 04-02linux命令頁(yè)面 linux命令頁(yè)面中文
隨機(jī)閱讀
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10C#中split用法實(shí)例總結(jié)
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 04-02jquery與jsp,用jquery
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 01-11Mac OSX 打開(kāi)原生自帶讀寫NTFS功能(圖文
- 01-10delphi制作wav文件的方法
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子


