スレッド プールが使い果たされた場合、バックグラウンドのバッチ コンパイルが原因で、デッドロックが発生する

文書翻訳 文書翻訳
文書番号: 821155 - 対象製品
この資料は、アーカイブされました。これは "現状のまま" で提供され、更新されることはありません。
すべて展開する | すべて折りたたむ

目次

概要

バックグラウンドのバッチ コンパイル実行時、すべてのワーカー スレッドが使用された場合、コンパイルが原因で Aspnet_wp.exe プロセスでデッドロックが発生することがあります。プロセス モデルに maxWorkerThreads = 20 を設定していて、実行中の Aspnet_wp.exe スレッドも 20 の場合、20 のワーカー スレッドすべてが、ManualResetEvent がシグナルされるのを待機します。イベントをシグナルする WaitCallback (BatchCompileDirectory) 関数は、空きスレッドができるまで実行されません。空きスレッドができることはありません。スレッド プールのすべてのスレッドを使用した後、バッチ コンパイルを必要とする状況を発生させて、このシナリオをシミュレートしてください。

イベント ビューアのアプリケーション ログに、以下のようなイベントが記録されることがあります。

イベント ID : 1003
説明 : デッドロック状態である可能性があるため、aspnet_wp.exe (PID: <xxx>) が繰り返されました。この 180 秒間に保留中の要求に対して応答は何も送信されていません。

詳細

バックグラウンドのバッチ コンパイルが原因でデッドロックが発生した場合、ワーカー スレッドは次のスタック トレースを返します。
Current frame: 
ChildEBP RetAddr  Caller,Callee
0c06f938 03187c87 (MethodDesc 0x3228200 +0x27 System.Web.Hosting.RecyclableArrayHelper.ReuseIntegerArray)
0c06f940 099f63e2 (MethodDesc 0x3223fc0 +0x1ea System.Web.Hosting.ISAPIWorkerRequest.FlushCachedResponse)
0c06f98c 799de84f (MethodDesc 0x79bac930 +0x57 System.Threading.WaitHandle.WaitOne)
0c06f9b0 099f4389 (MethodDesc 0x322d660 +0x59 System.Web.HttpWriter.GetBufferedLength)
0c06f9c4 099f68a8 (MethodDesc 0x94e68a8 +0x8 System.Web.Compilation.PreservedAssemblyEntry/BackgroundBatchCompiler.BeforeDoneWithSessionHandler)
0c06f9c8 099f4178 (MethodDesc 0x3224970 +0x350 System.Web.HttpRuntime.FinishRequest)

解決方法

修正プログラムの入手方法

この問題は、ASP.NET 修正プログラム パッケージ 1.1 (2003 年 6 月) で修正されています。関連情報を参照するには、以下の「サポート技術情報」 (Microsoft Knowledge Base) をクリックしてください。
821156 INFO: ASP.NET 1.1 June 2003 Hotfix Rollup Package
821156 [INFO] ASP.NET 1.1 修正プログラム ロールアップ パッケージ (2003 年 6 月)
この修正プログラムを個別に入手することはできません。ロールアップをインストールする必要があります。

: この修正プログラムを要求した場合は、ロールアップが送付されます。

修正プログラム (英語版) のファイル属性は次表のとおりです。ただし、これより新しい修正プログラムがリリースされている可能性もあります。各ファイルの日付および時刻は、世界協定時刻 (UTC) で示されています。ファイル情報に表示される時刻は、ローカル時刻に変換されています。UTC とローカル時刻との時差を確認するには、コントロール パネルの [日付と時刻] の [タイム ゾーン] タブを使用してください。
	             日付            時刻    バージョン      サイズ       ファイル名
		   -----------------------------------------------------------------------
		   07-Jun-2003  00:44  1.1.4322.910    253,952  Aspnet_isapi.dll
		   07-Jun-2003  00:44  1.1.4322.910     20,480  Aspnet_regiis.exe
		   07-Jun-2003  00:44  1.1.4322.910     32,768  Aspnet_wp.exe
		   15-May-2003  23:49                   33,522  Installpersistsqlstate.sql
		   15-May-2003  23:49                   34,150  Installsqlstate.sql
		   07-Jun-2003  12:52  1.1.4322.910  1,216,512  System.dll
		   07-Jun-2003  00:39                   14,472  Webuivalidation.js
		   07-Jun-2003  12:52  1.1.4322.910  1,249,280  System.Web.dll

関連情報

この資料は米国 Microsoft Corporation から提供されている Knowledge Base の Article ID 821155 (最終更新日 2003-11-13) を基に作成したものです。

プロパティ

文書番号: 821155 - 最終更新日: 2014年2月27日 - リビジョン: 2.1
この資料は以下の製品について記述したものです。
  • Microsoft ASP.NET 1.1
キーワード:?
kbnosurvey kbarchive kbqfe KB821155
"Microsoft Knowledge Baseに含まれている情報は、いかなる保証もない現状ベースで提供されるものです。Microsoft Corporation及びその関連会社は、市場性および特定の目的への適合性を含めて、明示的にも黙示的にも、一切の保証をいたしません。さらに、Microsoft Corporation及びその関連会社は、本文書に含まれている情報の使用及び使用結果につき、正確性、真実性等、いかなる表明・保証も行ないません。Microsoft Corporation、その関連会社及びこれらの権限ある代理人による口頭または書面による一切の情報提供またはアドバイスは、保証を意味するものではなく、かつ上記免責条項の範囲を狭めるものではありません。Microsoft Corporation、その関連会社 及びこれらの者の供給者は、直接的、間接的、偶発的、結果的損害、逸失利益、懲罰的損害、または特別損害を含む全ての損害に対して、状況のいかんを問わず一切責任を負いません。(Microsoft Corporation、その関連会社 またはこれらの者の供給者がかかる損害の発生可能性を了知している場合を含みます。) 結果的損害または偶発的損害に対する責任の免除または制限を認めていない地域においては、上記制限が適用されない場合があります。なお、本文書においては、文書の体裁上の都合により製品名の表記において商標登録表示、その他の商標表示を省略している場合がありますので、予めご了解ください。"

フィードバック

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com