五月综合激情婷婷六月,日韩欧美国产一区不卡,他扒开我内裤强吻我下面视频 ,无套内射无矿码免费看黄,天天躁,日日躁,狠狠躁

新聞動態(tài)

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

發(fā)布日期:2022-02-19 11:01 | 文章來源:源碼之家

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

如果系統(tǒng)開啟了coredump,準(zhǔn)確的說如果當(dāng)前的shell環(huán)境開啟了coredump,當(dāng)前shell環(huán)境下的程序崩潰退出時,會把當(dāng)時進程的棧的內(nèi)存狀態(tài)寫入core文件。使用gdb可以查看這個core文件中保存的棧的狀態(tài),gdb a.out core。(關(guān)于coredump的開啟和對shell的理解,請參考本人另一篇博客《使用dotnet-dump 查找 .net core 3.0 占用CPU 100%的原因解析》,關(guān)于gdb請參考《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文件會放在/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ù)大家的!

美國服務(wù)器租用

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部