日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

記一次 .NET某酒業業務系統崩潰分析

來源: 責編: 時間:2024-07-09 18:15:14 232觀看
導讀一、背景1. 講故事前些天有位朋友找到我,說他的程序每次關閉時就會自動崩潰,一直找不到原因讓我幫忙看一下怎么回事,這位朋友應該是第二次找我了,分析了下 dump 還是挺經典的,拿出來給大家分享一下吧。二、WinDbg 分析1.

一、背景

1. 講故事

前些天有位朋友找到我,說他的程序每次關閉時就會自動崩潰,一直找不到原因讓我幫忙看一下怎么回事,這位朋友應該是第二次找我了,分析了下 dump 還是挺經典的,拿出來給大家分享一下吧。h8028資訊網——每日最新資訊28at.com

二、WinDbg 分析

1. 為什么會崩潰

找崩潰原因比較簡單,用 !analyze -v 命令觀察一下便知。h8028資訊網——每日最新資訊28at.com

0:040> !analyze -vCONTEXT:  (.ecxr)eax=0afdf5dc ebx=0698ade8 ecx=00000001 edx=00000000 esi=0698ade8 edi=7eec0000eip=7753c5af esp=0afdf5dc ebp=0afdf62c iopl=0         nv up ei pl nz na po nccs=0023  ss=002b  ds=002b  es=002b  fs=0053  gs=002b             efl=00000202KERNELBASE!RaiseException+0x58:7753c5af c9              leaveResetting default scopeEXCEPTION_RECORD:  (.exr -1)ExceptionAddress: 7753c5af (KERNELBASE!RaiseException+0x00000058)   ExceptionCode: c0020001  ExceptionFlags: 00000001NumberParameters: 1   Parameter[0]: 8007042bPROCESS_NAME:  xxx.exe

從卦中數據看當前崩潰碼是 c0020001,查了下碼表說是 string綁定無效 ,截圖如下:h8028資訊網——每日最新資訊28at.com

圖片圖片h8028資訊網——每日最新資訊28at.com

這看起來有點無語呀,接下來觀察下線程棧。h8028資訊網——每日最新資訊28at.com

0:040> .ecxreax=0afdf5dc ebx=0698ade8 ecx=00000001 edx=00000000 esi=0698ade8 edi=7eec0000eip=7753c5af esp=0afdf5dc ebp=0afdf62c iopl=0         nv up ei pl nz na po nccs=0023  ss=002b  ds=002b  es=002b  fs=0053  gs=002b             efl=00000202KERNELBASE!RaiseException+0x58:7753c5af c9              leave0:040> k  *** Stack trace for last set context - .thread/.cxr resets it # ChildEBP RetAddr      00 0afdf62c 70e75e0b     KERNELBASE!RaiseException+0x5801 0afdf648 70f63bf5     clr!COMPlusThrowBoot+0x1a02 0afdf654 70b6f1da     clr!UMThunkStubRareDisableWorker+0x2503 0afdf67c 77a9571e     clr!UMThunkStubRareDisable+0x904 0afdf6bc 77a80f0b     ntdll!RtlpTpTimerCallback+0x7a05 0afdf6e0 77a809b1     ntdll!TppTimerpExecuteCallback+0x10f06 0afdf830 75c4344d     ntdll!TppWorkerThread+0x56207 0afdf83c 77a69802     kernel32!BaseThreadInitThunk+0xe08 0afdf87c 77a697d5     ntdll!__RtlUserThreadStart+0x7009 0afdf894 00000000     ntdll!_RtlUserThreadStart+0x1b

從卦中的線程棧來看,這里利用了 Windows線程池 的timer回調,回到 clr 之后主動拋了一個異常。h8028資訊網——每日最新資訊28at.com

2. 為什么會主動拋異常

要想知道這個答案需要分析下clr 的源碼,簡化后如下:h8028資訊網——每日最新資訊28at.com

// Disable from a place that is calling into managed code via a UMEntryThunk.extern "C" VOID __stdcall UMThunkStubRareDisableWorker(Thread * pThread, UMEntryThunk * pUMEntryThunk, Frame * pFrame){    // Check for ShutDown scenario.  This happens only when we have initiated shutdown     // and someone is trying to call in after the CLR is suspended.  In that case, we    // must either raise an unmanaged exception or return an HRESULT, depending on the    // expectations of our caller.    if (!CanRunManagedCode())    {        pThread->m_fPreemptiveGCDisabled = 0;        COMPlusThrowBoot(E_PROCESS_SHUTDOWN_REENTRY);    }}BOOL CanRunManagedCode(BOOL fCannotRunIsUserError, HINSTANCE hInst){    // If we are shutting down the runtime, then we cannot run code.    if (g_fForbidEnterEE == TRUE)        return FALSE;    // If we are finaling live objects or processing ExitProcess event,    // we can not allow managed method to run unless the current thread    // is the finalizer thread    if ((g_fEEShutDown & ShutDown_Finalize2) && !GCHeap::GetGCHeap()->IsCurrentThreadFinalizer())        return FALSE;    // If pre-loaded objects are not present, then no way.    if (g_pPreallocatedOutOfMemoryException == NULL)        return FALSE;    return TRUE;}

根據上面的源碼,應該就是CanRunManagedCode()函數返回false 導致的,那這個函數真的返回 false 嗎?可以用 Windbg 驗證下g_fForbidEnterEE 這個變量。h8028資訊網——每日最新資訊28at.com

0:040> dp clr!g_fForbidEnterEE L1712a2684  00000001

無語了,這個變量為true表示當前的CLR處于關閉狀態,應該是主線程調用了 Exit 方法,用 windbg 可以簡單驗證下。h8028資訊網——每日最新資訊28at.com

0:000> k00 0028d3b0 77549cd4     ntdll!NtQueryAttributesFile+0x1201 0028d3b0 70bf560b     KERNELBASE!GetFileAttributesW+0x7102 0028d3c8 710602a5     clr!CheckFileExistence+0x1a...39 0028ebc0 70d2684b     clr!WaitForEndOfShutdown_OneIteration+0x813a 0028ebc8 70d300e2     clr!WaitForEndOfShutdown+0x1b3b 0028ec08 70d1329e     clr!EEShutDown+0xad3c 0028ec14 70d132fb     clr!HandleExitProcessHelper+0x4d3d 0028ec70 70d2ff99     clr!EEPolicy::HandleExitProcess+0x503e 0028ec70 7115af3b     clr!ForceEEShutdown+0x313f 0028ec70 702a9faf     clr!SystemNative::Exit+0x4f

接下來研究下它要進入到什么托管方法中,這個答案就在 UMEntryThunk.m_pManagedTarget 字段里,參考源碼如下:h8028資訊網——每日最新資訊28at.com

class UMEntryThunk{private: // The start of the managed code const BYTE* m_pManagedTarget; // This is used for profiling. PTR_MethodDesc m_pMD;}

有了這些前置知識就可以用 windbg 輕松挖掘。h8028資訊網——每日最新資訊28at.com

0:040> kb 5 # ChildEBP RetAddr      Args to Child              00 0afdf62c 70e75e0b     c0020001 00000001 00000001 KERNELBASE!RaiseException+0x5801 0afdf648 70f63bf5     006e0fe0 0afdf67c 70b6f1da clr!COMPlusThrowBoot+0x1a02 0afdf654 70b6f1da     0698ade8 00580a38 0698ade8 clr!UMThunkStubRareDisableWorker+0x2503 0afdf67c 77a9571e     00000000 00000001 7d723ac9 clr!UMThunkStubRareDisable+0x904 0afdf6bc 77a80f0b     0afdf71c 006e0fe0 006f6c10 ntdll!RtlpTpTimerCallback+0x7a0:040> dp 00580a38 L200580a38  00386580 008f2eb80:040> !U 00386580Unmanaged code00386580 e9ab390000      jmp     00389f30...0:040> !ip2md 00389f30MethodDesc:   0018af94Method Name:  xxx._checkInput1(IntPtr, Boolean)Class:        00435a7cMethodTable:  0018afd8mdToken:      06000034Module:       0018a6a8IsJitted:     yesCodeAddr:     00389f30Transparency: Critical

通過一頓反解果然是一個托管回調函數,分析到這里ztm的開心哈,感覺馬上就要看到光了,仔細找了下代碼,果然是借助Windows線程池創建了一個定時事件,無語了,截圖如下:h8028資訊網——每日最新資訊28at.com

圖片圖片h8028資訊網——每日最新資訊28at.com

圖片圖片h8028資訊網——每日最新資訊28at.com

到這里就真相大白了,退出進程的時候一定要先調用C#的Dispose()方法把非托管的Timer給關掉,否則就會出現這種偶發的崩潰異常。h8028資訊網——每日最新資訊28at.com

3. 一些題外話

這個dump的錯誤碼非常有誤導性,一個是外部的c0020001 ,一個內部的 8007042Bh,尤其是搜內部的 8007042Bh 會把你帶入到誤區里,讓你修復系統文件啥的,其實就是一個固定的死值,沒有意義的,參見匯編代碼。h8028資訊網——每日最新資訊28at.com

0:000> ub 70f63bf5clr!UMThunkStubRareDisableWorker+0x7:70f63bd7 c9              leave70f63bd8 e8d47fc3ff      call    clr!CanRunManagedCode (70b9bbb1)70f63bdd 8b7508          mov     esi,dword ptr [ebp+8]70f63be0 85c0            test    eax,eax70f63be2 7511            jne     clr!UMThunkStubRareDisableWorker+0x25 (70f63bf5)70f63be4 b92b040780      mov     ecx,8007042Bh70f63be9 c7460800000000  mov     dword ptr [esi+8],070f63bf0 e8f721f1ff      call    clr!COMPlusThrowBoot (70e75dec)

所以還是多以代碼說話,少道聽途說陷入迷途不知返。h8028資訊網——每日最新資訊28at.com

三、總結

說實話這個dump分析起來還是挺有難度的,需要你對Windows線程池,clr源碼實現有一個基礎了解,否則很難構造出完整證據鏈。h8028資訊網——每日最新資訊28at.com

本文鏈接:http://m.www897cc.com/showinfo-26-99886-0.html記一次 .NET某酒業業務系統崩潰分析

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: C#開發混合Windows服務和Windows窗體程序

下一篇: 從ESB服務組合編排到NetflixConductor微服務編排

標簽:
  • 熱門焦點
Top 日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不
亚洲男人的天堂在线观看| 国产三区精品| 美日韩精品免费| 久久国产精品久久国产精品| 欧美中文字幕在线视频| 久久久久久有精品国产| 欧美成人性生活| 欧美日韩一区二区在线播放| 国产农村妇女精品| 国内精品久久久久影院优| 亚洲第一综合天堂另类专| 日韩视频中文字幕| 亚洲永久免费精品| 久久理论片午夜琪琪电影网| 欧美黄色精品| 国产精品嫩草久久久久| 韩国成人福利片在线播放| 亚洲清纯自拍| 校园春色国产精品| 欧美成人资源| 国产精品久久久久久久久婷婷| 国内精品99| 日韩视频一区二区三区| 欧美一区视频| 欧美久久影院| 国产视频观看一区| 亚洲免费观看高清完整版在线观看| 亚洲免费在线视频一区 二区| 久久美女性网| 欧美日韩亚洲视频一区| 国内精品视频在线播放| 一区二区久久| 久久久噜久噜久久综合| 欧美性猛交一区二区三区精品| 韩国三级电影久久久久久| 一区二区三区精品| 蜜臀久久99精品久久久久久9 | 亚洲在线免费观看| 免费成人黄色av| 国产美女搞久久| 亚洲免费高清| 久久夜色精品国产| 国产精品一区二区久久| 99精品免费| 久久亚洲高清| 国产日韩精品一区二区三区在线| 99ri日韩精品视频| 免费欧美视频| 在线成人黄色| 羞羞色国产精品| 国产精品成人播放| 亚洲美女视频在线免费观看| 久久影院午夜片一区| 国产三级精品在线不卡| 亚洲在线视频一区| 欧美三日本三级少妇三99| 亚洲欧洲久久| 免费亚洲电影| 在线成人中文字幕| 久久精品亚洲精品| 国产欧美一区二区精品性 | 欧美国产精品久久| 樱桃国产成人精品视频| 久久精品人人做人人爽| 国产欧美亚洲一区| 午夜精品久久久久久久99樱桃 | 午夜精品久久久久久久蜜桃app| 欧美日韩在线播放一区| 亚洲精品永久免费精品| 麻豆成人在线播放| 在线播放豆国产99亚洲| 久久久久九九九| 国产综合久久久久久鬼色| 欧美一级片久久久久久久| 国产精品人成在线观看免费| 亚洲视频综合在线| 国产精品s色| 亚洲一区区二区| 国产精品免费小视频| 亚洲欧美日韩久久精品| 国产精品蜜臀在线观看| 亚洲综合二区| 国产欧美精品一区| 欧美一区二区三区在线视频| 国产日韩在线看| 久久激情五月激情| 极品尤物一区二区三区| 久久影院午夜论| 亚洲国产精品久久久久婷婷老年| 你懂的亚洲视频| 亚洲理伦电影| 欧美特黄a级高清免费大片a级| 中文成人激情娱乐网| 国产精品激情av在线播放| 亚洲欧美激情视频| 国产日本欧美一区二区三区| 久久国产精品久久w女人spa| 黄色日韩网站| 欧美成人精品在线观看| av成人免费在线观看| 欧美性大战久久久久| 午夜精品久久久久久久99樱桃| 国产一区日韩二区欧美三区| 久久只有精品| 99精品欧美一区| 国产精品日日摸夜夜摸av| 久久精品视频在线看| 亚洲国产精品一区在线观看不卡| 欧美激情在线有限公司| 亚洲性xxxx| 国产一区日韩一区| 欧美成年人视频网站| 在线亚洲一区| 国产亚洲成年网址在线观看| 另类春色校园亚洲| 99在线热播精品免费99热| 国产精品一国产精品k频道56| 久久久久久久网| 久久美女性网| 亚洲福利小视频| 欧美日韩中文在线观看| 欧美亚洲综合网| 亚洲国产精品一区二区久| 国产精品久久77777| 久久久久久久一区| 亚洲人成艺术| 国产精品入口尤物| 欧美18av| 小黄鸭视频精品导航| 亚洲国产精品999| 国产精品美女视频网站| 欧美成年人视频网站欧美| 亚洲一区国产| 在线成人激情黄色| 国产精品久久77777| 久久久中精品2020中文| 一区二区免费在线视频| 国内精品嫩模av私拍在线观看| 欧美日韩另类综合| 久久精品国产一区二区电影| aa亚洲婷婷| 亚洲国产精品久久久久秋霞蜜臀| 国产精品理论片| 欧美成人日韩| 欧美在线观看视频一区二区| 日韩视频永久免费| 国产一区二区三区网站| 欧美啪啪一区| 久久亚洲不卡| 亚洲欧美另类在线| 亚洲精品少妇30p| 狠狠色综合网站久久久久久久| 欧美日韩一二区| 老司机成人网| 亚欧美中日韩视频| 夜夜嗨网站十八久久| 尹人成人综合网| 国产女人aaa级久久久级| 欧美日韩国产一区二区三区| 久久夜色精品国产噜噜av| 欧美一级专区| 亚洲无限av看| 亚洲激情不卡| 黄色精品在线看| 国产精品永久入口久久久| 欧美日韩精品欧美日韩精品一| 乱中年女人伦av一区二区| 久久riav二区三区| 亚洲在线免费| 亚洲私人影院| 一区二区激情| 99re8这里有精品热视频免费| 亚洲电影中文字幕| 黄色亚洲在线| 国产午夜亚洲精品羞羞网站 | 另类酷文…触手系列精品集v1小说| 亚洲一区日韩| 亚洲视频在线观看网站| 亚洲九九精品| 亚洲精品国精品久久99热| 在线观看欧美视频| 国精品一区二区三区| 国产日韩精品久久| 国产日韩欧美一区在线| 国产精品外国| 国产精品日韩一区二区| 国产精品高潮呻吟| 欧美日韩专区| 欧美日韩国内自拍| 欧美国产视频在线| 免费在线欧美黄色| 鲁鲁狠狠狠7777一区二区| 久久久人成影片一区二区三区观看 | 一个色综合导航| 亚洲另类自拍| 亚洲免费电影在线观看| 亚洲精品一区在线观看香蕉| 亚洲人成小说网站色在线| 最新高清无码专区| 亚洲人成网站在线播| 亚洲日本一区二区| 亚洲美女av网站| 一本一本久久| 亚洲视频欧美在线|