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

在迪慶州等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供網(wǎng)站設(shè)計制作、成都網(wǎng)站制作 網(wǎng)站設(shè)計制作按需開發(fā),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站建設(shè),全網(wǎng)營銷推廣,外貿(mào)營銷網(wǎng)站建設(shè),迪慶州網(wǎng)站建設(shè)費用合理。
如果系統(tǒng)開啟了coredump,準確的說如果當前的shell環(huán)境開啟了coredump,當前shell環(huán)境下的程序崩潰退出時,會把當時進程的棧的內(nèi)存狀態(tài)寫入core文件。使用gdb可以查看這個core文件中保存的棧的狀態(tài),gdb a.out core。(關(guān)于coredump的開啟和對shell的理解,請參考本人另一篇博客《gdb調(diào)試命令的使用及總結(jié)》)
core文件生成的位置默認是可執(zhí)行文件所在的位置,名稱默認為core,其位置和名稱是可以設(shè)置的,我的設(shè)置為:
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時間)。
下面是一個可以導(dǎo)致coredump的例程:
劃線處是會導(dǎo)致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ù)。 ————————————————
總結(jié)
以上所述是小編給大家介紹的linux下利用coredump技術(shù)追查進程崩潰原因,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復(fù)大家的!
成都創(chuàng)新互聯(lián)科技有限公司,經(jīng)過多年的不懈努力,公司現(xiàn)已經(jīng)成為一家專業(yè)從事IT產(chǎn)品開發(fā)和營銷公司。廣泛應(yīng)用于計算機網(wǎng)絡(luò)、設(shè)計、SEO優(yōu)化、關(guān)鍵詞排名等多種行業(yè)!
網(wǎng)頁標題:淺析Linux下利用coredump技術(shù)追查進程崩潰原因
標題網(wǎng)址:http://m.fisionsoft.com.cn/article/dpssoed.html


咨詢
建站咨詢
