青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 14,  comments - 57,  trackbacks - 0

  最近項目開始集中測試了,服務器程序經常crash,由于服務器一般情況下都是關閉了core的,所以好幾次都只能通過雜亂的日志來定位問題。
當然,我們可以通過ulimit來打開core開關,不過這可能帶來新的問題:我們的服務器程序每個core文件大概有1G多,測試期間如果頻繁crash,沒有注意及時清理,一不小心就會把磁盤寫滿,
而且core文件畢竟是和進程程序相關的,有時候找相應版本也是個麻煩事。

能否在程序crash的時候,將callStack以及參數和局部變量都記錄到日志里?
這個技術其實在游戲客戶端已經用了很多年了,一般游戲客戶端crash后,都會彈出一個是否發送錯誤的選擇框,其實就是發送的CallStack的日志和MiniDUmp文件。
要想記錄CallStack就必然涉及到Stack的遍歷,linux下的Stack遍歷使用很簡單,簡單的backtrace就可以搞定,man backtrace就有現成的例子,
這比windows下復雜的頭疼的StackWalk好用的多。

解決了Stack遍歷問題后,還剩下一個問題:如何在程序crash的時候得到通知執行我們自己的dump代碼?
在Windwos下有SEH異常來實現這個功能,而linux下可以通過使用信號在進程crash的時候執行自己的處理代碼。

好了,開始寫個簡單代碼測試下:
首先設置幾個主要crash信號的處理函數
signal(SIGSEGV, &DumpHelper::OnCrash);
signal(SIGABRT, &DumpHelper::OnCrash);
signal(SIGFPE, &DumpHelper::OnCrash);

在OnCrash里我們用前面提到的backtrace系列函數,來記錄堆棧:
void* szStackFrame[100];
int nFrameCount = backtrace(szStackFrame, 100);
char** strFrameInfo = backtrace_symbols(szStackFrame, nFrameCount); 
char szDumpFileName[1024] = {0};
snprintf(szDumpFileName, sizeof(szDumpFileName), "dump_%u.log", (unsigned int)time(NULL) );
FILE* pFile = fopen(szDumpFileName, "wb");
if(!pFile) return;
for(int i = 0; i < nFrameCount; i++)
{
    fprintf(pFile, "%s\n", strFrameInfo[i]);
}
fclose(pFile);
free(strFrameInfo);

接著,設置幾個嵌套調用的函數:
void fun()
{
 //assert(0);
 int* p = NULL;
 *p =3;
}

void fun1()
{
 fun();
}

void fun2()
{
 fun1();
}

void fun3()
{
 fun2();
}

最后,我們在main函數里執行fun3,注意編譯的時候帶上-rdynamic 選項。

運行下,果然可以打印基本的堆棧,不過馬上,發現了新的問題:這個堆棧信息也太簡陋了,只有調用函數的名字,其余的參數、局部變量完全沒有,
這個和gdb能看到的callStack差距也太大了。
解決這個問題最簡單的辦法就是用gdb來打印堆棧,在這里,gdb和其他程序有區別,如果你試圖通過 echo "bt"|gdb -p XXX>a.txt來獲得堆棧,那將會非常失望,
根本不起作用,google了下,基本沒什么解決辦法。
不過gdb 可以從文件讀入指令,例如 gdb XXX<cmddata,這給了我們機會,
system("echo  \"bt full|gcore\">testcmd");
  char dbx[160]={0};
     sprintf(dbx, "gdb -p %d ./main<testcmd >gdbdump_%d.log", getpid(), getpid() );
  system(dbx);

測試運行,發現可以打印詳細的堆棧,不過,要求機器上有gdb.
上面的命令還dump了一個core文件,不過這個core文件的堆棧信息是錯誤的,我不知道為什么。。。。

多線程環境下使用上述辦法,只能輸出一個線程的堆棧,需要先獲取線程數目,然后逐個線程打印堆棧。

最后,為了避免影響正常的coredump,要在OnCrash的處理函數里將信號的處理函數設置為默認。
如果我一定要有core呢,setrlimit吧,去掉core限制即可。
posted on 2011-04-10 14:47 feixuwu 閱讀(1047) 評論(0)  編輯 收藏 引用 所屬分類: 游戲開發
<2025年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

文章轉載請注明出處

常用鏈接

留言簿(11)

隨筆分類

隨筆檔案

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            麻豆精品精华液| 激情综合中文娱乐网| 亚洲一区二区三区精品在线| 亚洲精品国产精品国自产观看浪潮| 久久午夜电影| 欧美国产日韩xxxxx| 亚洲三级视频在线观看| 一本一本a久久| 亚洲一区二区三区高清不卡| 亚洲欧美在线看| 久久精品国产99国产精品| 免费成人在线观看视频| 亚洲精品一二三| 亚洲在线观看免费视频| 久久在线视频| 欧美亚韩一区| 在线免费一区三区| 亚洲香蕉视频| 欧美jizz19hd性欧美| 亚洲电影免费在线观看| 亚洲视频日本| 美女尤物久久精品| 国产免费观看久久黄| 亚洲九九九在线观看| 欧美一区二区黄| 亚洲精品乱码久久久久久日本蜜臀| 亚洲资源在线观看| 欧美国产日产韩国视频| 国产在线拍偷自揄拍精品| 一本色道久久99精品综合| 久久影音先锋| 亚洲综合色自拍一区| 欧美激情一区二区三区高清视频| 国产视频一区在线观看| 国产精品99久久久久久有的能看| 另类av一区二区| 亚洲一区二区三区三| 欧美激情综合五月色丁香小说| 激情久久久久久| 欧美在线观看网站| 这里只有精品视频在线| 欧美国产第二页| 91久久久一线二线三线品牌| 久久亚洲电影| 久久精品论坛| 国外成人在线视频| 欧美在线1区| 在线视频中文亚洲| 欧美视频不卡中文| 一区二区三区产品免费精品久久75| 免费在线欧美黄色| 久久综合999| 在线观看欧美激情| 另类酷文…触手系列精品集v1小说| 先锋影院在线亚洲| 国产一区二区福利| 美女免费视频一区| 久久色中文字幕| 亚洲国产91精品在线观看| 蜜桃久久精品乱码一区二区| 久久资源在线| 日韩午夜激情| 99在线精品视频| 国产精品高潮久久| 午夜影院日韩| 欧美一区在线直播| 黄色精品一二区| 欧美不卡激情三级在线观看| 久久躁日日躁aaaaxxxx| 欧美激情一区二区久久久| 国产午夜精品全部视频播放| 亚洲男女自偷自拍| 亚洲视频在线免费观看| 国产精品一区二区三区久久| 久久精品国产免费观看| 久久久久久网站| 亚洲剧情一区二区| 一区二区三区免费看| 国产伦精品一区二区三区照片91 | 亚洲欧美国产一区二区三区| 99视频国产精品免费观看| 国产精品私拍pans大尺度在线| 欧美在线观看你懂的| 久久亚洲精品一区二区| 亚洲免费av观看| 亚洲一区999| 国外成人免费视频| 亚洲精品美女在线观看| 国产欧美日韩在线播放| 欧美黄色一级视频| 国产精品草草| 欧美成人按摩| 国产精品久久久久久久7电影| 久久久噜噜噜久久久| 欧美精品成人一区二区在线观看| 小黄鸭视频精品导航| 美国成人直播| 久久国产精品一区二区| 欧美黄色大片网站| 久久久噜噜噜久久| 欧美三级不卡| 欧美成人亚洲成人| 国产裸体写真av一区二区| 亚洲欧洲中文日韩久久av乱码| 国产农村妇女精品一区二区| 亚洲黑丝在线| 一色屋精品亚洲香蕉网站| 在线视频精品| aⅴ色国产欧美| 久久久久高清| 久久精品国产96久久久香蕉| 欧美三区在线视频| 欧美国产亚洲精品久久久8v| 国产精品亚洲аv天堂网| 亚洲六月丁香色婷婷综合久久| 在线精品视频一区二区| 午夜精品免费在线| 亚洲一区二区三区乱码aⅴ| 欧美成人高清视频| 久久躁狠狠躁夜夜爽| 国产日韩精品视频一区二区三区| 日韩视频一区二区| 9久草视频在线视频精品| 久久综合久久综合久久| 久久精品一区二区| 国产亚洲网站| 久久国产色av| 久久久久久久久综合| 国产亚洲欧美另类一区二区三区| 一区二区三区日韩精品视频| 在线亚洲精品福利网址导航| 在线亚洲+欧美+日本专区| a4yy欧美一区二区三区| 欧美精品v国产精品v日韩精品| 欧美黄色一区| 日韩视频不卡| 欧美日产一区二区三区在线观看| 亚洲国产高清在线| 亚洲麻豆视频| 欧美日韩第一区| 亚洲视频电影图片偷拍一区| 性伦欧美刺激片在线观看| 国产欧美日韩| 欧美在线观看你懂的| 久久一日本道色综合久久| 亚洲国产精品一区二区www| 女人香蕉久久**毛片精品| 亚洲高清在线视频| 一区二区三区产品免费精品久久75 | 国产亚洲欧美日韩在线一区| 性色av一区二区三区在线观看 | 国产小视频国产精品| 久久电影一区| 欧美激情精品久久久久久久变态 | 欧美激情一区二区三区全黄| 亚洲三级视频| 欧美午夜宅男影院在线观看| 亚洲在线成人精品| 噜噜噜躁狠狠躁狠狠精品视频 | 欧美综合二区| 一区在线观看| 欧美日韩在线一二三| 性娇小13――14欧美| 欧美国产精品人人做人人爱| 日韩亚洲一区二区| 国产婷婷色一区二区三区四区| 久久久一二三| 一区二区不卡在线视频 午夜欧美不卡在 | 蜜臀久久99精品久久久久久9| 亚洲人体偷拍| 欧美在线在线| 亚洲精品中文字幕有码专区| 国产精品视频一区二区高潮| 久久精品综合一区| 99在线精品观看| 欧美成人日韩| 久久福利一区| 一区二区三区日韩欧美| 狠狠v欧美v日韩v亚洲ⅴ| 欧美日韩国产麻豆| 久久久久综合| 小嫩嫩精品导航| 一区二区日韩精品| 欧美激情中文字幕在线| 久久国产精品99国产精| 欧美日韩国产成人在线| 久久精品成人| 亚洲欧美日本精品| 一本色道久久加勒比精品| 欧美凹凸一区二区三区视频| 欧美一区国产二区| 亚洲一区二区三区免费视频| 亚洲黄色片网站| 影音先锋成人资源站| 国产日本欧美视频| 国产精品国产三级国产aⅴ入口| 欧美aⅴ一区二区三区视频| 久久久国际精品| 午夜伦理片一区| 亚洲一区二区三区777|