精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

骨灰級Windows實用教程:如何在一分鐘內(nèi)解決Windows 10的崩潰問題

譯文
系統(tǒng) Windows 系統(tǒng)運維
當(dāng)操作系統(tǒng)崩潰時,即產(chǎn)生藍屏死機等問題,你應(yīng)當(dāng)如何設(shè)置你的Windows 10系統(tǒng)。本文將幫助你盡快找到大多數(shù)故障發(fā)生的原因和尋求合適的解決方案。

【51CTO.com快譯】當(dāng)我剛開始使用Windows 10時,我就能夠在不使用谷歌搜索電源按鈕圖標(biāo)的情況下關(guān)閉筆記本電腦;這可以說是相對于Windows 8的很大的一個改進。于是,我的下一個興趣點轉(zhuǎn)到:當(dāng)操作系統(tǒng)崩潰時,即產(chǎn)生藍屏死機(Blue Screen of Death,后文簡稱“BSOD”)時(參考下圖),應(yīng)當(dāng)怎么辦。

本文將向你展示如何設(shè)置你系統(tǒng),以便當(dāng)它出現(xiàn)問題時,你可以盡快找到大多數(shù)故障發(fā)生的原因。

藍屏

在Windows 10中,藍屏看起來與Windows 8/8.1一個模樣。藍屏中顯示的仍然是皺眉的圖形表情以及顯示消息“Your PC ran into a problem . . .”不過,此屏幕看起來比原始的藍屏更友好一些。但是,一個真正友好的屏幕顯示會告訴你問題的原因以及如何修復(fù)它。藍屏問題其實不會很難,因為大多數(shù)藍屏死機引起的原因經(jīng)常是由于第三方驅(qū)動程序的錯誤行為所導(dǎo)致的,而這些行為很容易被MS Windows調(diào)試器所識別。

對于早期版本的操作系統(tǒng),請參閱以下內(nèi)容:

必須明確的是,本文論及的是系統(tǒng)崩潰問題,而不是應(yīng)用程序崩潰或系統(tǒng)掛起。在系統(tǒng)完全崩潰時,操作系統(tǒng)會總結(jié)性提示某種對象出現(xiàn)了錯誤(如內(nèi)存損壞),繼續(xù)操作可能會導(dǎo)致嚴重的或災(zāi)難性的結(jié)果。因此,操作系統(tǒng)試圖關(guān)閉,并盡可能做到干凈地結(jié)束——在該過程中保存系統(tǒng)狀態(tài)信息——然后以一種刷新環(huán)境和帶有待分析的調(diào)試信息重新啟動(如果設(shè)置成這樣做的話)。

為什么Windows 10會崩潰

可以肯定的是,自1985年問世以來,Windows特征及規(guī)模不斷發(fā)展壯大并越來越穩(wěn)定。然而,盡管操作系統(tǒng)中內(nèi)置了保護機制,崩潰現(xiàn)象仍然不斷發(fā)生。

Windows歷來都是以“層保護模式”著稱,而Windows 10操作系統(tǒng)也不例外。Windows 10運行于兩個層模式下:一個是用戶模式(Ring 3層);另一個是內(nèi)核模式(Ring 0層)。這個設(shè)計思想是很容易理解的:在內(nèi)核模式下運行核心操作系統(tǒng)和設(shè)備驅(qū)動程序代碼,而在用戶模式下運行軟件應(yīng)用程序和用戶模式驅(qū)動程序。因此,應(yīng)用程序想要訪問操作系統(tǒng)服務(wù)和硬件的話,它們必須要調(diào)用充當(dāng)代理服務(wù)的Windows服務(wù)。因此,通過阻止用戶模式代碼直接訪問到內(nèi)核模式,操作系統(tǒng)操作就會普遍得到保障。

問題是:內(nèi)核模式代碼出錯了!在大多數(shù)情況下,由于在內(nèi)核模式下活動的第三方驅(qū)動程序發(fā)生了錯誤的調(diào)用,例如對并不存在的內(nèi)存的訪問或者改寫操作系統(tǒng)代碼,導(dǎo)致系統(tǒng)故障。當(dāng)然,Windows本身是很少出現(xiàn)故障的。

Windows 10崩潰時,從哪里尋求幫助

當(dāng)出現(xiàn)BSOD問題時,你可以通過很多地方進行求助。下面列出其中的幾個幫助去處。例如,ConfigSafe網(wǎng)站能夠告訴你是什么驅(qū)動程序發(fā)生了變化,而AutorunCheck網(wǎng)站會告訴你哪些Windows自動運行設(shè)置已被更改。這兩處幫助資源都能夠有效地幫助你探測出導(dǎo)致系統(tǒng)失敗的罪魁禍?zhǔn)住4送猓總€人都應(yīng)該擁有一本《Windows Internals》;它簡直是每個網(wǎng)絡(luò)管理員和首席信息官應(yīng)該參考的“圣經(jīng)”,尤其是本書第二部分的第14章“崩潰轉(zhuǎn)儲分析”(Crash Dump Analysis)更值得你認真閱讀。

當(dāng)我問Mark Russinovic(《Windows Internals》作者之一):為什么網(wǎng)絡(luò)管理員或首席信息官(而不是程序員)應(yīng)該閱讀這本書?他說,“如果是由你管理Windows系統(tǒng),但你卻不知道進程和線程的區(qū)別,不知道Windows如何管理虛擬內(nèi)存和物理內(nèi)存,不知道內(nèi)核模式驅(qū)動程序可導(dǎo)致系統(tǒng)崩潰,那么你正在妨礙你自己。因此,理解這些概念對于充分理解故障轉(zhuǎn)儲及能夠發(fā)現(xiàn)相關(guān)線索是至關(guān)重要的。

所以,WinDbg工具能夠提供系統(tǒng)出錯時有關(guān)系統(tǒng)狀態(tài)的數(shù)據(jù),而《Windows Internals》則更能夠把那些神秘的數(shù)據(jù)變成可操作的信息,從而進一步幫助你解決問題。

幫助你發(fā)現(xiàn)BSOD的部分參考網(wǎng)站

何謂內(nèi)存轉(zhuǎn)儲?

所謂“內(nèi)存轉(zhuǎn)儲”,是指在系統(tǒng)崩潰時系統(tǒng)內(nèi)存中內(nèi)容的拷貝或快照。轉(zhuǎn)儲文件非常重要,因為它們可以顯示:在系統(tǒng)出問題時誰正在做什么。轉(zhuǎn)儲文件因其內(nèi)容的特別性而很難解析,除非你知道要尋找什么。

Windows 10可以產(chǎn)生五種類型的內(nèi)存轉(zhuǎn)儲文件,下面針對每一種作有關(guān)描述。

1.自動內(nèi)存轉(zhuǎn)儲

位置:%SystemRoot%\Memory.dmp ;

大小:操作系統(tǒng)內(nèi)核大小。

自動內(nèi)存轉(zhuǎn)儲是你安裝Windows 10時的默認選擇選項。它是為了支持“系統(tǒng)托管”頁面文件配置而創(chuàng)建的。這種“系統(tǒng)托管”頁面文件配置已被更新,以便減少在磁盤上的頁面文件大小(主要針對小型SSD),但也有益于使用大容量RAM的服務(wù)器。自動內(nèi)存轉(zhuǎn)儲選項將生成一個內(nèi)核內(nèi)存轉(zhuǎn)儲;不同的是,當(dāng)你選擇“自動”(Automatic)方式時它允許SMS進程減少頁面文件大小——小于RAM的大小。

如果你想檢查或編輯你的系統(tǒng)分頁文件大小,請切換到以下位置(并請參考下面圖形示意):

“Windows10按鈕—控制面 板—系統(tǒng)與安全—系統(tǒng)—高級系統(tǒng)設(shè)置—性能—設(shè)置——高級——修改”。

2.活動內(nèi)存轉(zhuǎn)儲

位置:%SystemRoot%\Memory.dmp

大小:三倍于內(nèi)核大小或者自動轉(zhuǎn)儲文件的大小。

活動內(nèi)存轉(zhuǎn)儲是微軟最近研制出的新模式。盡管比完全內(nèi)存轉(zhuǎn)儲尺寸小得多,但其尺寸大約也是內(nèi)核轉(zhuǎn)儲大小的三倍。這是因為它包括內(nèi)核空間和用戶空間兩個部分。在我的測試系統(tǒng)上,我使用了4GB RAM+英特爾酷睿i7 64位處理器配置運行Windows 10,活動內(nèi)存轉(zhuǎn)儲大約占了1.5GB。因為有時需要傳送轉(zhuǎn)儲文件,所以我對其進行了壓縮,減小到大約500MB。

3.完整內(nèi)存轉(zhuǎn)儲

位置:%SystemRoot%\Memory.dmp

大小:已安裝的RAM尺寸+1MB。

完整(或全部)內(nèi)存轉(zhuǎn)儲使用最大的轉(zhuǎn)儲文件,因為它包含了所有的Windows操作系統(tǒng)使用的物理內(nèi)存。你可以假定該文件約等于已安裝的RAM的大小。隨著許多系統(tǒng)都各自占用多個GB的存儲空間,這會迅速導(dǎo)致出現(xiàn)存儲問題,尤其是當(dāng)你面對比偶爾系統(tǒng)崩潰更多的場合時。一般來說,請盡量使用自動轉(zhuǎn)儲文件方案。

4.內(nèi)核內(nèi)存轉(zhuǎn)儲

位置:%SystemRoot%\Memory.dmp

大小:約等于被核心模式組件所占用的物理內(nèi)存大小。

內(nèi)核轉(zhuǎn)儲所用文件大小約等于Windows 10內(nèi)核所占用RAM的大小,在我的測試系統(tǒng)上大約占700MB。進一步壓縮的話,將減小近80%,約為150MB。內(nèi)核轉(zhuǎn)儲文件的優(yōu)點之一是,它包含分析所需要的二進制文件。默認情況下,內(nèi)核轉(zhuǎn)儲設(shè)置會創(chuàng)建一個核心轉(zhuǎn)儲文件,只保存最新的內(nèi)容并為每個事件創(chuàng)建一個小型轉(zhuǎn)儲。

5.小內(nèi)存轉(zhuǎn)儲(又稱小型轉(zhuǎn)儲)

位置:%SystemRoot%\Minidump

大小:在x86平臺上至少占64K,在x64平臺上至少占128KB(在我的Windows10測試PC上使用約279K)。

小型轉(zhuǎn)儲能夠提供特定的內(nèi)存頁面,其中的數(shù)據(jù)包含出故障時寄存器指向的位置,同時還包含出錯線程的堆棧信息。導(dǎo)致它們這么小的原因是,它們并不包含任何失敗時仍處在內(nèi)存中的二進制或可執(zhí)行文件。但是,這些文件對于調(diào)試器的后續(xù)分析是極其重要的。

【提示】有關(guān)Windows 10其它類似的參考文章有:《如何探測Windows10中攜帶了錯誤的設(shè)備驅(qū)動程序》和《導(dǎo)致Windows 10藍屏的原因是什么?》。

只要你在創(chuàng)建了轉(zhuǎn)儲文件的計算機上進行調(diào)試,WinDbg程序就可以在系統(tǒng)根目錄文件夾(除非在轉(zhuǎn)儲文件創(chuàng)建后系統(tǒng)更新改變了二進制文件)中找到上述內(nèi)容。另外,調(diào)試器應(yīng)該能夠通過SymServ(微軟的符號文件在線存儲)自動找到它們。除非用戶作了更改,通常Windows 10會被設(shè)置為最新事件創(chuàng)建自動轉(zhuǎn)儲文件,并針對每一個崩潰的事件創(chuàng)建小型轉(zhuǎn)儲,為系統(tǒng)生命周期內(nèi)所有系統(tǒng)崩潰事件提供歷史記錄。

配置Windows 10生成合適內(nèi)存轉(zhuǎn)儲

打開“控制面板”程序并切換到“啟動與恢復(fù)”窗口:

“Windows10按鈕—控制面板—系統(tǒng)與安全—系統(tǒng)—高級系統(tǒng)設(shè)置—啟動與恢復(fù)—設(shè)置——自動內(nèi)存轉(zhuǎn)儲”。

在最后的窗口“啟動與恢復(fù)”中,請選擇“自動內(nèi)存轉(zhuǎn)儲”選項(如下圖所示),并勾選“自動重新啟動”(通常這兩個選項都是Windows 10下的默認設(shè)置)。

安裝WinDbg

系統(tǒng)要求:為了進行基于WinDbg的崩潰分析而安裝一臺PC,你將需要以下內(nèi)容:

  • 32位或64位Windows 10:這取決于運行調(diào)試器的處理器,你可以使用32位或64位調(diào)試工具。請注意,轉(zhuǎn)儲文件是基于x86平臺還是基于x64平臺上生成的并不重要。
  • WinDbg:這是Windows 10提供的Windows SDK的Windows調(diào)試工具部分,你可以從微軟網(wǎng)站免費下載。
  • 硬盤空間:大約250MB的硬盤空間(不包括用于轉(zhuǎn)儲文件或符號文件的存儲空間)。
  • 互聯(lián)網(wǎng):在線互聯(lián)網(wǎng)連接

下載WinDbg:從微軟網(wǎng)站下載sdksetup.exe(約1.2MB)。注意,此下載將直接啟動安裝程序,你將從中選擇要安裝的組件。你可以轉(zhuǎn)到微軟網(wǎng)站的硬件開發(fā)人員中心頁面,然后向下滾動到“Get debugging tools”,然后選擇“Debugging Tools for Windows 10 (WinDbg)”(下面的“A”項),也可以啟動立即下載(下面的“B”項)。

A)微軟硬件開發(fā)中心(https://msdn.microsoft.com/en-us/windows/hardware/hh852365);

B)自動下載(http://go.microsoft.com/fwlink/p/?LinkId=536682)。

空間需求:你可以忽略“Estimated disk space required”選項,直到你取消選擇不需要的工具。請確保取消選擇所有除了“Debugging Tools for Windows”以外的選項,其中包括內(nèi)核和用戶模式調(diào)試器,以及幫助和使用工具提示信息等。除非你想進行編程,否則你并不需要安裝其他模塊;這樣,你將節(jié)省大量的磁盤空間。在這臺測試機中安裝所占用的磁盤空間最大從2.5GB到最小大約250MB。

運行sdksetup.exe:在系統(tǒng)中安裝軟件開發(fā)工具包(SDK),你將使用它來分析內(nèi)存轉(zhuǎn)儲文件。請記住,它可以是一臺運行另一個版本的Windows系統(tǒng)(并不需要一定運行Windows 10)的32位或64位計算機。關(guān)鍵步驟如下:

1.啟動sdksetup.exe。

2.指定安裝位置:默認安裝位置是C:\Program Files (x86)\Windows Kits\10\。你可以選擇默認,還可以選擇另一個位置來定義你想安裝的軟件路徑。

3.接受或者拒絕Windows隱私問題。

4.接受許可協(xié)議。

5.取消選擇除了選項“Debugging Tools for Windows”外的所有內(nèi)容。

“符號”到底有多重要?

安裝完WinDbg后,但在調(diào)用轉(zhuǎn)儲文件之前,你需要符號表文件。符號文件相對于軟件很像高速公路上的出口標(biāo)記;它們會告訴你所在地是哪里——如果你停下車來的話。其實,它們只不過是把源代碼編譯成可執(zhí)行文件(從高級語言變成機器代碼)過程中的一種副產(chǎn)品而已。在此過程中,編譯器使用一組標(biāo)識符、標(biāo)識符在程序中的位置以及屬性信息創(chuàng)建符號文件。

然而,程序不需要此信息來執(zhí)行,所以符號通常存儲在一個單獨的文件中。這將減少可執(zhí)行文件的大小,從而導(dǎo)致占用較少的磁盤空間和更快的加載與運行速度。此外,這些符號文件通常不是與操作系統(tǒng)或應(yīng)用程序一起發(fā)行的。那么,問題在于:當(dāng)一個程序?qū)е孪到y(tǒng)出現(xiàn)故障問題時,操作系統(tǒng)只知道問題在其中出現(xiàn)的十六進制地址,但不知道那里是誰以及他在做什么。幸運的是,微軟提供了對SymServ的訪問,這一舉措最終解決了問題。

當(dāng)打開某一內(nèi)存轉(zhuǎn)儲時,WinDbg會查看可執(zhí)行文件(如.exe,.dll等)并提取有關(guān)版本信息。然后,它創(chuàng)建一個到微軟網(wǎng)站上的SymServ的請求,其中包括版本信息和描述信息的精確的符號表位置信息。正如前面提到的,它不會針對你正在進行故障排除的特定操作系統(tǒng)下載所有的符號;它將只下載它所需要的內(nèi)容。

在我們的示例情況下,即是針對Windows 10 PC系統(tǒng),符號文件對應(yīng)的文件夾總共有22MB大小。在運行眾多的崩潰測試后,該文件夾大約占35MB。在另一個系統(tǒng)上,我運行了來自于多臺不同個人電腦的若干測試結(jié)果發(fā)現(xiàn):上述文件夾大小仍然不足100MB。因此,只需記住,如果你打開來自于其他機器(可能使用Windows操作系統(tǒng)的其他變種)上的文件,你的文件夾可能會繼續(xù)增長。

或者,你可以選擇下載和存儲來自微軟網(wǎng)站的完整的符號文件。在這樣做之前,請注意:針對每一個符號包,你應(yīng)該保留至少1GB的可用磁盤空間。這是因為,除了存儲文件所需的空間外,你也需要空間來存儲臨時文件。即使在今天硬盤成本很低的情況下,使用的空間仍然值得注意。

  • 每一個x86符號包可能需要750MB或者更多的硬盤空間。
  • 每一個x64符號包可能需要640MB或者更多的硬盤空間。

符號程序包都是非累積性的,除非另行說明;否則,如果你使用的是Windows 10的SP2版本,那么,在你為SP2安裝符號程序之前,你需要針對原始的RTM版本和SP1版本也都安裝對應(yīng)的符號包程序。

【提示】如果你想下載符號文件并想把它們保存到本地,那么請務(wù)必讀一下網(wǎng)址https://msdn.microsoft.com/en-us/windows/hardware/gg463028.aspx處提供的資料。

SymServ(又名:SymSrv/符號表服務(wù)器),是一個極為重要的服務(wù),由微軟免費提供,用于確保準(zhǔn)確的內(nèi)存轉(zhuǎn)儲分析。要想使用這個服務(wù),你只需配置一下WinDbg來定位這個服務(wù),則SymServ就會自動檢索特定于提供轉(zhuǎn)儲內(nèi)容的確切版本W(wǎng)indows的符號。而且,在分析完一臺機器中的轉(zhuǎn)儲文件后,如果你從另一臺機器上調(diào)用一個轉(zhuǎn)儲文件,那么WinDbg和SymServ都將自動檢索相應(yīng)于該版本的操作系統(tǒng)的符號。

配置WinDbg

從上面的Windows 10界面上,選擇Windows 10按鈕,然后選擇“WinDbg |更多| 以管理員運行”。

然后,你會看到一個有幾個菜單項和一個空白主窗口區(qū)域的窗口。打開轉(zhuǎn)儲文件之前,你必須告訴WinDbg在哪里可以找到符號文件。

配置WinDbg:把Windows轉(zhuǎn)儲文件與適當(dāng)?shù)姆栁募P(guān)聯(lián)起來不僅是知道正運行的操作系統(tǒng)的版本號的問題。操作系統(tǒng)存在無數(shù)種變體,這并不是一個顯而易見的事實。唯一可以肯定哪個文件是正確的方式是讓SymServ幫你找到它。

設(shè)置符號文件路徑:Windows存在大量的符號表文件,因為每一個版本、每一次更新、每一個補丁程序和無數(shù)的一次性變體都會各自產(chǎn)生一個新文件。而使用錯誤的符號來評價一個轉(zhuǎn)儲文件將像使用波士頓地圖來導(dǎo)航舊金山一樣糟糕。

進入如下路徑:

srv*c:\cache*http://msdl.microsoft.com/download/symbols

在上面命令的*c:\cache*位置處,請確保替換成你想要存儲符號的位置。

在本例中,我們使用“c:\symbols”。然后選擇【OK】。

【注意】請確保你的防火墻允許訪問msdl.microsoft.com,而不僅僅是網(wǎng)址www.microsoft.com。

如果你沒有可查看的內(nèi)存轉(zhuǎn)儲,怎么辦呢?請不要擔(dān)心。你可以自己生成一個!是的:你可以導(dǎo)致你的系統(tǒng)崩潰,并且安全地這樣做。有好幾種不同的方式可以實現(xiàn)這一目的,但最好的方法是使用一種稱為NotMyFault的由Russinovich研發(fā)的工具。

你可以從網(wǎng)址https://download.sysinternals.com/files/NotMyFault.zip處下載NotMyFault,你也可以從圖書《Windows Internals》宣傳網(wǎng)站的鏈接處http://technet.microsoft.com/en-us/sysinternals/bb963901.aspx下載。該工具中包括了一個選項允許加載行為錯誤的驅(qū)動程序(這需要系統(tǒng)管理特權(quán))。下載之后,你可以在桌面上創(chuàng)建一個相應(yīng)的快捷方式來簡化訪問。

【提示】圖書《Windows Internals》第二部分的第14章完全涵蓋了NotMyFault工具的使用說明,還有更重要的崩潰轉(zhuǎn)儲分析。

【警告】使用NotMyFault將創(chuàng)建一個系統(tǒng)崩潰,但是我在使用該工具時從未出現(xiàn)過問題。不過,在實際應(yīng)用中也不敢做任何保證,特別是在計算機領(lǐng)域。所以,請準(zhǔn)備好你的系統(tǒng),讓任何需要訪問它的人注銷幾分鐘。把任何包含你可能失去信息的文件都保存一下,然后關(guān)閉所有應(yīng)用程序。適當(dāng)準(zhǔn)備后,然后關(guān)閉這臺機器,重新啟動,你會注意到一個小型轉(zhuǎn)儲和一個內(nèi)核(或你選擇的任何大小)轉(zhuǎn)儲都應(yīng)該已經(jīng)創(chuàng)建成功。

打開轉(zhuǎn)儲文件

定位轉(zhuǎn)儲文件在Windows系統(tǒng)中轉(zhuǎn)儲文件位于兩個地方,具體取決于你打開的類型︰

  • 所有轉(zhuǎn)儲文件(除了小型轉(zhuǎn)儲外)都位于c:\Windows\MEMORY.DMP;
  • 小型轉(zhuǎn)儲類型對應(yīng)的轉(zhuǎn)儲文件位置:c:\Windows\Minidump\[實際的Minidump文件名]

請注意,不像其他命名為MEMORY.DMP的其他類型的轉(zhuǎn)儲文件一樣,小型轉(zhuǎn)儲會被自動單獨命名;因此,不會覆蓋以前的文件。這是一個不錯的特性,因為它們的體積都很小。

打開轉(zhuǎn)儲文件:要打開你選擇的文件,請選擇命令“File | Open Crash Dump”。

如果你看到如下提示,請立即停止:

*** WARNING: Unable to verify timestamp for ntoskrnl.exe *** ERROR: Module load completed but symbols could not be loaded for ntoskrnl.exe

這是很重要的。當(dāng)你在WinDbg輸出的開始附近看到這兩行消息時,這意味著你不會得到你需要的分析結(jié)果。當(dāng)“Bugcheck Analysis”自動運行并顯示下面的消息后,剛才的說法將被進一步證實。

當(dāng)你看到下面的消息:

“*** ERROR: Symbol file could not be found. Defaulted to export symbol for ntkrnlmp.exe. . .”

這意味著,WinDbg找不到文件的ntkrnlmp.exe(Windows OS內(nèi)核本身)正確的符號位置,也就無法進行正確的分析。

***** Kernel symbols are WRONG. Please fix symbols to do analysis

導(dǎo)致上述錯誤的原因可能存在如下幾種:

  • 沒有提供路徑或者路徑錯誤:沒有提供指向符號文件的路徑或者路徑不正確(可以檢查一下誤輸入空格等筆誤)。請檢查“Symbol Path”(參考上圖中的“Setting symbol file path”)部分。
  • 連接失敗:請檢查你的互聯(lián)網(wǎng)連接,以確保它可以正確工作。
  • 訪問被阻止:防火墻阻止訪問符號文件或文件在檢索過程中損壞。請確保沒有防火墻阻止訪問msdl.microsoft.com(它可能只會允許www.microsoft.com訪問)。

請注意,如果防火墻最初阻擋WinDbg下載一個符號表,那么這可能導(dǎo)致一個損壞的文件。如果取消防火墻阻止并嘗試再次下載符號文件后仍不能工作,則說明該文件仍然是損壞的。最快的解決方法是:關(guān)閉WinDbg,刪除符號文件夾(你最有可能設(shè)置在c:\symbols這個位置),并取消防火墻阻止。然后,重新打開WinDbg和轉(zhuǎn)儲文件。調(diào)試器將重新創(chuàng)建此文件夾并重新下載符號。切記:不要馬上進行分析,直到確保更正此問題。

如果你看到以下錯誤,那么請不用擔(dān)心:

*** WARNING: Unable to verify timestamp for myfault.sys *** ERROR: Module load completed but symbols could not be loaded for myfault.sys

這意味著,調(diào)試器尋找在文件myfault.sys上的信息。然而,由于它是一個第三方的驅(qū)動程序,所以它內(nèi)部根本就沒有符號,因為微軟不會存儲所有的第三方驅(qū)動程序(【說明】myfault.sys是由屬于微軟旗下的SysInternals網(wǎng)站提供的,但它肯定不是一個常規(guī)的微軟產(chǎn)品。在我們的示例應(yīng)用中,它用于代表第三方驅(qū)動程序)。關(guān)鍵是,你可以忽略此錯誤消息。典型情況下,軟件供應(yīng)商不會與驅(qū)動程序一起提供相應(yīng)的符號文件,而且他們也沒有必要針對你的目的而提供;而在沒有這些符號文件情況下,你仍然可以找出存在問題的驅(qū)動程序。

觀察為什么Windows 10會崩潰

假設(shè)一切都很順利,那么你只需要打開WinDbg產(chǎn)生的轉(zhuǎn)儲文件來確定操作系統(tǒng)和二進制文件,找到正確的符號表文件、下載所需的文件并進行基本的分析即可。如果這是WinDbg首次運行在此系統(tǒng)上,或你正在查看一個來自于另外一個系統(tǒng)(你從未在其上為轉(zhuǎn)儲文件加載過文件)的轉(zhuǎn)儲文件,那么,這可能需要花費一點時間。在接下來的問題分析中,進度可能會加快,因為大部分或所有需要的符號都已經(jīng)存在于硬盤上了。

接下來,我們所分析的信息范圍包括:WinDbg的版本,打開的轉(zhuǎn)儲文件的位置和名稱,正在使用的符號搜索路徑,以及一點總結(jié)性分析。

在我們的示例中,我們知道“Probably caused by : myfault.sys”這一行提示是正確的,因為它正好是NotMyFault驅(qū)動程序的名稱。

通常情況下,在診斷Windows崩潰的原因時還需要更多的信息。例如,你可能已經(jīng)認出某某驅(qū)動程序,但你可能不確信它是最新的版本;你也有可能還沒有識別出驅(qū)動程序或知道誰開發(fā)的此程序;或者在其他情況下,某某驅(qū)動程序?qū)嶋H上可能正好來自微軟自己并關(guān)聯(lián)到操作系統(tǒng)內(nèi)核,這使得它不太可能成為嫌疑程序。要了解更多信息,你通常需要的都是兩個如下命令。

!analyze –v與lmvm

命令比較

多年來,微軟公司一直繼續(xù)改進和完善WinDbg。例如,在上面列出的兩個命令可以同時被輸入到WinDbg屏幕底部“kd >”提示符命令窗口中。現(xiàn)在,這兩個命令都可以通過在WinDbg界面中選擇一個熱鏈接而啟動

使用!analyze –v 

使用命令!analyze –v的輸出將提供有關(guān)系統(tǒng)崩潰事件的更詳細的說明信息。在我們的示例程序中,分析結(jié)果已經(jīng)準(zhǔn)確地描述了測試驅(qū)動程序(myfault.sys)的行為。在此,測試程序指示此測試驅(qū)動程序在訪問一個很高級別的中斷地址。

命令!Analyze –v的輸出結(jié)果DRIVER_IRQL_NOT_LESS_OR_EQUAL (d1)

在這里,程序試圖以過高的中斷請求級別(IRQL)訪問一個可分頁(或完全無效)地址。這通常是由于驅(qū)動程序使用了不正確的地址所導(dǎo)致的。

注意,BUCKET_ID_FUNC_OFFSET是到可疑模塊的基地址的距離,而問題代碼正駐留于此地址處。

最重要的部分是,被WinDbg命名的可疑模塊是myfault;既然我們知道這是一個第三方驅(qū)動程序,那么它很有可能就是“罪犯”。

為了獲得一幅更好的圖片來觀察當(dāng)操作系統(tǒng)出現(xiàn)問題時究竟發(fā)生了什么事情,我們不妨來觀察一下堆棧中的信息。

觀察調(diào)試器顯示的堆棧輸出一直是很重要的,因為它能夠顯示出哪個程序處于活動狀態(tài),是否是它正在做的操作導(dǎo)致了系統(tǒng)的崩潰。當(dāng)觀察堆棧時,總是要觀察堆棧最右端存在的任何第三方驅(qū)動程序,并且要永遠記住堆棧是以逆時間順序顯示的。因此,事件發(fā)生的順序是從底部到頂部;隨著每個新的任務(wù)由系統(tǒng)執(zhí)行,它會顯示在頂部,把以前的動作壓入堆棧中。在下圖展示的堆棧中,你可以看到NotMyFault/myfault正處于活動狀態(tài)。緊接著驅(qū)動程序的最后一項活動,Windows 10聲明了一個PageFault,然后是一個BugCheck,從而停止了系統(tǒng)的執(zhí)行(藍屏)。

在技術(shù)會議上,我常用的一個比方是:堆棧遍歷好比是你踏入一個房間,而此房間中剛剛發(fā)生了一宗謀殺案,你發(fā)現(xiàn)地板上躺著死者尸體,而有人正站在他的旁邊,手中還握著正冒煙的手槍。這并不意味著他就一定是兇手,但他肯定是頭號嫌疑犯。

NotMyFault/myfault模塊處于活動狀態(tài)

假設(shè)我們需要關(guān)于可疑模塊的更多的信息,那么我們可以運行命令lmvm。請參考下圖。

使用lmvm [模塊名]

現(xiàn)在,既然我們已經(jīng)有了一個可疑的模塊,那么再更多地了解有關(guān)它的信息就很重要了。這里有兩個關(guān)鍵點:第一,確保它確實是一個第三方模塊;第二,確定它是否是一個過時的模塊。lmvm命令能夠告訴我們這兩種信息以及更多的內(nèi)容(請見上圖)。例如,我們可以看到:模塊的制造商是SysInternals,它有一個時間戳是2012年4月。

當(dāng)然,我們知道SysInternals已經(jīng)被微軟并入。然而,該模塊幾乎就不是一個內(nèi)核操作系統(tǒng)驅(qū)動程序,所以它正好可以作為我們的演示目的來擔(dān)當(dāng)?shù)谌津?qū)動程序這一角色。而且,也不太可能出現(xiàn)一個只有四年壽命的驅(qū)動程序就需要更新。如果這是真實的情況,例如,驅(qū)動程序是一個視頻驅(qū)動程序,那么幾乎可以肯定一定會存在一個帶有補丁的更新的驅(qū)動程序。從lmvm工具中,你會知道應(yīng)該同哪一個供應(yīng)商聯(lián)系以更新有關(guān)驅(qū)動程序和信息;當(dāng)然,有可能是要安裝一個更新的版本。

雖然大多數(shù)BSOD錯誤容易歸因于第三方驅(qū)動程序,但有些并不那么清楚。在這些情況下,原因可能是從因系統(tǒng)過熱導(dǎo)致機箱風(fēng)扇故障到錯誤的內(nèi)存模塊等任何情況。

我們不妨來回顧一下:那些沒有明確或一致原因的系統(tǒng)崩潰通常都是由內(nèi)存問題引起的。進行內(nèi)存檢查存在兩種值得推薦的方法:一種是使用Windows 10內(nèi)存診斷程序;另一種是使用Memtest86

Windows有罪嗎?

也許沒有。多年來,許多人都責(zé)怪Windows操作系統(tǒng)的崩潰問題,而事實上,由于Windows自身原因?qū)е卤罎⒌那闆r極少。通常情況下,當(dāng)把Windows中的某代碼塊命名為culprit時,通常是其他一些驅(qū)動程序發(fā)出請求要求Windows組件執(zhí)行一項操作卻傳遞了一個錯誤的指令,例如告訴它寫入一個并不存在的內(nèi)存地址等。在這種情況下,操作系統(tǒng)通常被視為“持有確鑿證據(jù)的罪犯”,但其實他只是按照吩咐的去做了;這使得識別請求的初始發(fā)起者往往成為一項艱巨的任務(wù)。

防病毒、備份和其他實用程序怎么樣呢?人們常常看到像那些防病毒和備份工具這樣的驅(qū)動程序正是使用了類似于“culprit”這樣的命名。然而,他們可能不是真正的“壞蛋”。這種實用程序必須處于活動狀態(tài),因為它們必須時刻關(guān)注文件變化活動;這意味著,無論發(fā)生了什么事情,都會經(jīng)常在堆棧上發(fā)現(xiàn)它們的蹤跡。

不管你是否使用谷歌搜索引擎找到了一個名字為“culprit”的罪魁禍?zhǔn)祝闼龅降娜魏螁栴}都有可能已被其他人經(jīng)歷過,而且在互聯(lián)網(wǎng)上存在無數(shù)的地方可能提供相應(yīng)的幫助信息。

最后,當(dāng)你發(fā)現(xiàn)你將能夠很快在沒有其他幫助并免費解決大多數(shù)BSOD問題時,你閱讀本文以及設(shè)置WinDbg的時間將會很好地得到賠償。請記住:仔細研究一下《Windows Internals》將會極大擴展你的新發(fā)現(xiàn)技能。

原文標(biāo)題:Hardcore Windows: How to solve Windows 10 crashes in less than a minute,作者:Dirk A.D. Smith

【51CTO譯稿,合作站點轉(zhuǎn)載請注明原文譯者和出處為51CTO.com】

責(zé)任編輯:趙寧寧 來源: 51CTO.com
相關(guān)推薦

2019-06-25 08:47:56

Windows 10Windows快速訪問

2009-09-21 16:20:12

2017-03-23 15:10:15

Windows 10Windows系統(tǒng)權(quán)限

2017-03-30 19:28:26

HBase分布式數(shù)據(jù)

2023-10-11 12:45:49

Windows系統(tǒng)

2021-10-05 15:44:32

Windows 11Windows微軟

2015-11-12 10:32:40

GitHub控制系統(tǒng)分布式

2022-07-18 06:16:07

單點登錄系統(tǒng)

2020-05-21 19:46:19

區(qū)塊鏈數(shù)字貨幣比特幣

2018-06-26 05:23:19

線程安全函數(shù)代碼

2017-07-06 08:12:02

索引查詢SQL

2017-02-21 13:00:27

LoadAverage負載Load

2018-07-31 16:10:51

Redo Undo數(shù)據(jù)庫數(shù)據(jù)

2011-02-21 17:48:35

vsFTPd

2024-06-21 15:03:00

2017-03-08 13:13:21

Windows 7Windows激活工具

2020-07-09 07:37:06

數(shù)據(jù)庫Redis工具

2018-12-12 22:51:24

Java包裝語言

2020-07-17 07:44:25

云計算邊緣計算IT

2016-09-12 17:28:45

云存儲應(yīng)用軟件存儲設(shè)備
點贊
收藏

51CTO技術(shù)棧公眾號

免费久久99精品国产自| 2020久久国产精品| 亚洲v在线观看| 欧美激情护士| 国产精品成人免费| 国产伦精品一区二区三区照片91| 久久人妻免费视频| 香蕉国产精品| 日韩精品在线观看网站| 亚洲第一天堂久久| 丝袜诱惑一区二区| 综合在线观看色| 狠狠爱一区二区三区| 无码人妻丰满熟妇区bbbbxxxx| 亚洲国产一区二区三区在线播放 | 伊人春色之综合网| 日韩欧美国产三级| 999精品视频在线| 成年人视频免费在线播放| 中文一区二区在线观看| 国产区日韩欧美| 国产精品羞羞答答在线| 久久综合导航| 久久久久久久久久国产精品| 日韩av片在线免费观看| 自拍视频一区| 精品美女一区二区三区| 中文字幕第一页在线视频| 欧美大片高清| 午夜精品福利一区二区三区蜜桃| 一区二区三区免费看| 久草视频在线看| 97se亚洲国产综合自在线| 99爱精品视频| 99久久99久久久精品棕色圆| 麻豆成人综合网| 国产精品吊钟奶在线| 日韩精品久久久久久免费| 亚洲精品综合| 久久久亚洲欧洲日产国码aⅴ| 成人在线观看小视频| 色999日韩| 国产一区二区三区在线观看网站 | 国产精品大陆在线观看| 久久久午夜影院| 亚洲无线一线二线三线区别av| 久久69精品久久久久久久电影好 | 91亚洲精品一区二区| 欧美特级黄色片| 久久激情中文| 日韩美女免费线视频| 国产精品视频一区在线观看| 午夜一级久久| 日本一区二区不卡| 日本视频免费观看| 日本va欧美va欧美va精品| 日韩美女视频免费看| 成人小视频在线播放| 日韩精品乱码av一区二区| 日本欧美中文字幕| 国产精品传媒在线观看| 麻豆久久久久久久| 91精品国产综合久久香蕉| 国产精品久久久久久久免费| 国产一区日韩二区欧美三区| 91国产在线免费观看| 亚洲精品一级片| 99久久夜色精品国产网站| 久久久久久欧美精品色一二三四| 欧美成人综合在线| 国产欧美精品日韩区二区麻豆天美| 亚洲成人一区二区三区| 麻豆tv在线| 一区二区三区在线视频播放| 成人午夜精品久久久久久久蜜臀| 一个人www视频在线免费观看| 欧美亚洲一区三区| www.五月天色| 久久这里只有精品一区二区| 亚洲色图狂野欧美| 精品亚洲乱码一区二区| 亚洲国产高清一区| 国产激情999| 国产免费叼嘿网站免费| 99视频精品在线| 日韩av高清在线播放| 精品孕妇一区二区三区| 婷婷一区二区三区| 亚洲人辣妹窥探嘘嘘| 免费观看亚洲天堂| 精品亚洲aⅴ在线观看| 亚洲AV成人无码网站天堂久久| 亚洲色图国产| 热re99久久精品国产66热| 在线播放一级片| 北岛玲一区二区三区四区| 日韩色妇久久av| 秋霞在线视频| 欧洲一区二区av| 苍井空张开腿实干12次| 欧美精品一区二区三区中文字幕 | 亚洲精品ady| 精品伦精品一区二区三区视频密桃| 亚洲视频综合| 国产在线精品成人一区二区三区| 人妻少妇精品无码专区久久| 国产精品美女久久久久aⅴ | 一区二区日本伦理| 爱情岛亚洲播放路线| 4438亚洲最大| 久久亚洲无码视频| 在线日韩中文| 91免费福利视频| 成人免费高清在线播放| 五月天亚洲精品| 男插女视频网站| 久久国产电影| 国产精品www| 天天干视频在线| 伊人色综合久久天天| 9久久婷婷国产综合精品性色 | 国产91精品久久久久久久网曝门| 午夜老司机精品| 成人性生活av| 欧美成人vps| 永久久久久久久| 久草热8精品视频在线观看| 蜜桃精品久久久久久久免费影院 | 999成人网| 国产精品扒开腿做爽爽爽视频| 色婷婷视频在线| 亚洲一区二区三区在线播放| 久久无码人妻一区二区三区| 亚洲国产精品日韩专区av有中文| 国产视频999| 一级日本在线| 欧美日韩国产a| 国产精品久久久久久久av| 亚洲综合国产| 老牛影视免费一区二区| 日韩精品av| 日韩精品中文字幕在线| 久久久精品福利| 黑人与亚洲人色ⅹvideos| 久草精品视频| 欧美夫妻性生活xx| 国产福利第一页| 亚洲欧美偷拍卡通变态| 欧美性猛交xxxx乱大交91| 国产精品久久久乱弄 | 国产在线视频在线| 日本精品在线播放| 欧美激情第一页xxx| 成人精品在线播放| 亚洲一区二区高清| 欧美大喷水吹潮合集在线观看| 亚洲国产高清一区| 欧美lavv| 国产成人免费| 久久精品国产清自在天天线 | 中文字幕一区二区三区在线乱码 | 午夜成人亚洲理伦片在线观看| 免费成人在线观看| 一区二区精品国产| 4438五月综合| 九九九久久久久久| 五月天婷婷激情网| 欧洲一区二区av| 国产午夜精品理论片| 国产成人免费视频一区| 国产av天堂无码一区二区三区| 亚洲成aⅴ人片久久青草影院| 奇米四色中文综合久久| 亚洲欧美视频一区二区| 日韩视频一区二区在线观看| 日韩精品一区二区三| 国产欧美日韩中文久久| 夜夜爽久久精品91| 亚洲少妇在线| 一区二区在线观| 国产精品videossex| 日韩av手机在线看| 18+激情视频在线| 日韩成人在线视频网站| 在线观看免费视频一区| 亚洲一区二区三区中文字幕在线| 在线观看福利片| 国产成人亚洲综合色影视| 亚洲精品无码久久久久久| 99国产精品一区二区| 精品国产电影| 欧美一级在线| 3344国产精品免费看| 久久久久久国产精品免费无遮挡| 亚洲国产第一页| 在线观看国产黄| 欧美日韩免费网站| 日本少妇aaa| 2021中文字幕一区亚洲| 久久黄色一级视频| 日韩精品免费视频人成| 国产二区视频在线| 日本一区二区免费高清| 国产日韩一区二区三区| 亚洲综合视频| 国产999在线观看| 77thz桃花论族在线观看| 久久天天躁狠狠躁夜夜av| 女人天堂在线| 亚洲第一av网站| 国产日本精品视频| 91成人免费在线视频| 青青草av在线播放| 一区二区三区日韩欧美精品| av资源在线免费观看| 久久久久久久久久久久久久久99 | 国产清纯白嫩初高生在线观看91 | 国产刺激高潮av| 91精品国产欧美一区二区| 一二三区免费视频| 午夜a成v人精品| 久久99久久久| 亚洲欧美一区二区不卡| 国产三级精品三级观看| 国产三级三级三级精品8ⅰ区| 黄色在线免费播放| 国产激情一区二区三区| 一级黄色在线播放| 久久国产精品一区二区| 久久久精品麻豆| 亚洲免费婷婷| 日本中文字幕片| 亚洲欧美bt| 国产99久久九九精品无码| 极品尤物久久久av免费看| 国产1区2区3区中文字幕| 亚洲精品91| 波多野结衣激情| 91精品啪在线观看国产18 | 欧美黄色一级生活片| 91欧美激情一区二区三区成人| 久久人人妻人人人人妻性色av| 懂色av中文字幕一区二区三区| 在线观看网站黄| 国产宾馆实践打屁股91| 潘金莲一级淫片aaaaaaa| 国产精品亚洲成人| 涩视频在线观看| 成人精品视频一区二区三区尤物| 亚洲一二三四五| 国产精品一二二区| 成年女人免费视频| av亚洲精华国产精华精华| av鲁丝一区鲁丝二区鲁丝三区| av在线不卡电影| 久久国产精品影院| 国产亚洲综合av| 三级黄色片在线观看| 亚洲日本在线天堂| 国产人妻精品一区二区三区不卡| 亚洲精品国产无套在线观| 国产精品白浆一区二小说| 精品日本高清在线播放 | 久久一区二区三区四区五区 | 日韩精品一级| 国产乱码精品一区二区三区中文 | 麻豆成人免费视频| 欧美三级电影网站| www.国产麻豆| 亚洲美女精品久久| 在线播放日本| 欧美黑人视频一区| 小视频免费在线观看| 国产精品露脸自拍| 在线精品视频一区| 欧美精品v日韩精品v国产精品| 精品一二三区| www.亚洲成人网| 视频一区欧美精品| 91欧美一区二区三区| 99精品欧美一区二区三区小说| 欧美特黄一区二区三区| 亚洲卡通动漫在线| yjizz国产| 在线不卡的av| 视频一区二区三区国产 | 欧美二级三级| 忘忧草精品久久久久久久高清| 欧美精品久久久久久久自慰 | 中文字幕18页| 国产欧美日韩精品一区| 国产一级理论片| 欧美伊人久久久久久久久影院 | 精品三级国产| 久久久免费看| 欧美福利网址| 久久精品免费网站| 成人黄色777网| 小向美奈子av| 色呦呦国产精品| 黄色三级网站在线观看| 日韩中文字幕视频在线观看| 91吃瓜在线观看| 91夜夜未满十八勿入爽爽影院| 亚洲aa在线| 国产精品久久久久久久乖乖| 老色鬼精品视频在线观看播放| 亚洲av成人片色在线观看高潮 | 中文字幕精品无| 精品久久久久久久久久久久久久久久久 | 伊人再见免费在线观看高清版| 久久久精品午夜少妇| 久久久久99人妻一区二区三区| 国产精品女同一区二区三区| 久久久成人免费视频| 亚洲第一页在线| 尤物在线网址| 成人免费xxxxx在线观看| 精品国产一区二区三区小蝌蚪| 久久久久久久久久久视频| 豆国产96在线|亚洲| 外国一级黄色片| 欧美老女人第四色| 国产高清视频在线| 欧美性资源免费| 久久九九热re6这里有精品| 免费观看亚洲视频| 精彩视频一区二区| 亚洲欧美综合7777色婷婷| 欧美性受极品xxxx喷水| 你懂的在线观看| 欧美又大又硬又粗bbbbb| 欧美三级电影在线| 国产毛片视频网站| 成人av片在线观看| 精品一区在线视频| 精品久久久久久久久久久久久久久久久| a免费在线观看| 91精品黄色| 欧美激情一级片一区二区| 欧美日韩久久婷婷| 综合精品久久久| 99热这里只有精品3| 美女av一区二区三区| 精品一区二区三区中文字幕| 91麻豆天美传媒在线| 国产麻豆91精品| 欧美成人777| 精品久久久久香蕉网| av资源网在线播放| 久久精品欧美| 日韩在线一区二区三区| 亚洲一级黄色录像| 欧美日韩免费高清一区色橹橹 | 久久视频国产| а 天堂 在线| 亚洲精品五月天| 囯产精品久久久久久| 国产91精品久| 成人免费在线观看av| 中文字幕视频三区| 亚洲午夜免费电影| 四虎精品在线| 国产精品你懂得| 亚洲电影影音先锋| 久久久老熟女一区二区三区91| 日韩欧美亚洲国产一区| av一区在线观看| 亚洲一区免费网站| 国产伦理一区| 精品伦精品一区二区三区视频密桃| 欧美一三区三区四区免费在线看| 黄色污污视频在线观看| 欧美精品中文字幕一区二区| 久久成人免费网| 亚洲一区 视频| 亚洲色图美腿丝袜| 日本少妇精品亚洲第一区| 六月激情综合网| 国产精品国产自产拍在线| 蜜桃91麻豆精品一二三区| 国产激情久久久| 欧美午夜影院| 精品无码人妻一区二区免费蜜桃| 56国语精品自产拍在线观看| 爱啪啪综合导航| 亚洲综合网中心| 成人国产精品免费观看动漫| 黄色污污视频软件| 久久久久久久久久久久av| 精品视频99| 人妻换人妻a片爽麻豆| 欧美日韩中文字幕精品| gogo久久| 中国一区二区三区| 91亚洲精品久久久蜜桃| 国产日韩欧美中文字幕| 日韩av电影手机在线| 国内自拍视频一区二区三区| 99精品全国免费观看|