概要
當您在 Internet 信息服務 (IIS) 6.0 中遇到被鎖死的情況時,應用程序事件日志中會出現類似下面這樣的錯誤信息:
Event Type: Warning
Event Source: W3SVC-WP
Event Category: None
Event ID: 2262
Date: 7/29/2003
Time: 12:08:58 PM
User: N/A
Computer: ComputerName
Description:ISAPI 'C:\WINNT\Microsoft.Net\Framework\v1.1.4322\ASPnet_isapi.dll' reported itself as unhealthy for the following reason:'Deadlock detected'.
在系統事件日志中會出現類似下面這樣的錯誤信息:
Event Type: Warning
Event Source: W3SVC
Event Category: None
Event ID: 1013
Date: 7/29/2003
Time: 12:09:34 PM
User: N/A
Computer: ComputerName
Description:A process serving application pool 'DefaultAppPool' exceeded time limits during shut down.The process id was '2756'.
為診斷程序生成轉儲文件
IIS 6.0 有一項叫做“孤立工作進程”的新功能。此功能使您能在預定要回收的進程終止之前對其進行檢查。孤立工作進程可用來在進程中附加一個調試程序並生成一個供調查使用的轉儲文件。
注意:當進程運行在 IIS 5.0 兼容模式中時,此功能不可用。
創建一個批處理文件,在一個工作進程被孤立時執行
1.啟動記事本。
2.將下面的代碼粘貼到記事本中:
@if "%_echo%"=="" echo off
setlocal
set TIMESTAMP=%DATE:~-9%_%TIME%
set TIMESTAMP=%TIMESTAMP:/=_%
set TIMESTAMP=%TIMESTAMP::=_%
set TIMESTAMP=%TIMESTAMP:.=_%
set TIMESTAMP=%TIMESTAMP: =_%
set FILENAME=c:\crash_%TIMESTAMP%.dmp
set LOG=c:\log.txt
set COMMAND=c:\debuggers\cdb.exe -c ".dump /o /mhf %FILENAME%;q" -p %1
echo %COMMAND% > %LOG%
%COMMAND%
endlocal
3.將文件保存為文件名.cmd。在這個例子中,我們把文件命名為 action.cmd。您也可以隨意給文件起別的名字。
注意:您可能必須修改調試程序的位置和您想要生成轉儲文件的位置。
配置孤立工作進程設置
1.在命令提示符處鍵入以下命令,然後按 ENTER 鍵:
cd \Inetpub\adminscripts
2.要使孤立工作進程的功能可用,需要在命令提示符下鍵入以下命令: adsutil.vbs SET W3SVC/AppPools/DefaultAppPool/OrphanWorkerProcess TRUE
3.在命令提示符下,設置當進程預定要回收時運行的可執行文件。例如,在這種情況下使用在“創建一個批處理文件,在一個工作進程被孤立時執行”一節創建的批處理文件: adsutil.vbs SET W3SVC/AppPools/DefaultAppPool/OrphanActionExe "c:\action.cmd"
adsutil.vbs SET W3SVC/AppPools/DefaultAppPool/OrphanActionParams "%%1%%"
注意:請確保 OrphanActionExe 選項指向在“創建一個批處理文件,在一個工作進程被孤立時執行”一節創建的批處理文件的位置。還要保證 W3wp.exe 進程對該文件有讀取和執行權限。