IIS の ASP.NET Core モジュール (ANCM)
Note
これは、この記事の最新バージョンではありません。 現在のリリースについては、この記事の .NET 8 バージョンを参照してください。
警告
このバージョンの ASP.NET Core はサポート対象から除外されました。 詳細については、「.NET および .NET Core サポート ポリシー」を参照してください。 現在のリリースについては、この記事の .NET 8 バージョンを参照してください。
重要
この情報はリリース前の製品に関する事項であり、正式版がリリースされるまでに大幅に変更される可能性があります。 Microsoft はここに示されている情報について、明示か黙示かを問わず、一切保証しません。
現在のリリースについては、この記事の .NET 8 バージョンを参照してください。
ASP.NET Core モジュール (ANCM) は、ネイティブな IIS モジュールであり、IIS パイプラインにプラグインされ、ASP.NET Core アプリケーションが IIS と連携できるようにします。 IIS で ASP.NET Core アプリを実行するには、次のいずれかのようにします。
- IIS ワーカー プロセス (
w3wp.exe
) の内部で ASP.NET Core アプリをホストします。これは、インプロセス ホスティング モデルと呼ばれています。 - Kestrel サーバーが実行されているバックエンドの ASP.NET Core アプリに、Web 要求を転送します。これは、アウトプロセス ホスティング モデルと呼ばれています。
各ホスティング モデルの間にはトレードオフがあります。 パフォーマンスと診断が向上するため、既定ではインプロセス ホスティング モデルが使用されます。
詳細および構成のガイダンスについては、次のトピックを参照してください:
ASP.NET Core モジュール (ANCM) をインストールする
ASP.NET Core モジュール (ANCM) は、.NET Core ホスティング バンドルから .NET Core ランタイムと共にインストールされます。 ASP.NET Core モジュールは、.NET のサポート対象リリースとの上位互換性および下位互換性があります。
破壊的変更とセキュリティ アドバイザリは、アナウンス リポジトリで報告されます。 ラベル フィルターを選択すると、特定のバージョンにアナウンスを限定できます。
次のリンクを使用してインストーラーをダウンロードします。
現在の .NET Core ホスティング バンドルのインストーラー (直接ダウンロード)
以前のバージョンのモジュールのインストールなどの詳細については、ホスティング バンドルに関する記事を参照してください。
ASP.NET Core アプリを IIS サーバーに発行する手順のチュートリアルについては、「IIS に ASP.NET Core アプリを発行する」を参照してください。
ASP.NET Core モジュール (ANCM) はネイティブな IIS モジュールであり、次のいずれかを目的として、IIS パイプラインにプラグインされます。
- IIS ワーカー プロセス (
w3wp.exe
) の内部で ASP.NET Core アプリをホストします。これは、インプロセス ホスティング モデルと呼ばれています。 - Kestrel サーバーを実行しているバックエンドの ASP.NET Core アプリに Web 要求を転送します。これは、アウト プロセス ホスティング モデルと呼ばれています。
サポートされている Windows バージョン:
- Windows 7 以降
- Windows Server 2012 R2 以降
インプロセス ホスティングの場合、モジュールでは IIS HTTP サーバー (IISHttpServer
) と呼ばれる IIS 用のインプロセス サーバー実装が使用されます。
アウト プロセスでホストする場合、モジュールは Kestrel に対してのみ機能します。 このモジュールは HTTP.sys では機能しません。
ホスティング モデル
インプロセス ホスティング モデル
ASP.NET Core アプリの既定はインプロセス ホスティング モデルです。
インプロセスでホストする場合は、次の特性が適用されます。
Kestrel サーバーの代わりに、IIS HTTP サーバー (
IISHttpServer
) が使用されます。 インプロセスの場合、CreateDefaultBuilder により UseIIS が呼び出され、次が実行されます。IISHttpServer
を登録します。- ASP.NET Core モジュールの背後で実行するときにサーバーがリッスンする、ポートとベース パスを構成します。
- スタートアップ エラーをキャプチャするホストを構成します。
requestTimeout 属性 は、インプロセス ホスティングには適用されません。
アプリ プールをアプリ間で共有することはサポートされていません。 アプリごとに 1 つのアプリ プールを使用します。
Web 配置を使用するとき、または配置に
app_offline.htm
ファイルを手動で置くときは、開いている接続がある場合、アプリがすぐにシャットダウンされないことがあります。 たとえば、WebSocket 接続によってアプリのシャットダウンが遅れる可能性があります。アプリとインストールされているランタイム (x64 または x86) のアーキテクチャ (ビット) は、アプリ プールのアーキテクチャと一致する必要があります。
クライアントの切断が検出されます。 クライアントが切断されると、
HttpContext.RequestAborted
キャンセル トークンが取り消されます。ASP.NET Core 2.2.1 以前の場合、GetCurrentDirectory は、アプリのディレクトリではなく、IIS によって開始されたプロセスのワーカー ディレクトリを返します (たとえば、
w3wp.exe
に対してC:\Windows\System32\inetsrv
)。アプリの現在のディレクトリを設定するサンプル コードについては、
CurrentDirectoryHelpers
クラスに関するページを参照してください。SetCurrentDirectory
メソッドを呼び出します。 GetCurrentDirectory の後続の呼び出しによって、アプリのディレクトリが指定されます。インプロセス ホスティングの場合、ユーザーを初期化するために内部で AuthenticateAsync が呼び出されることはありません。 そのため、認証のたびに要求を変換するための IClaimsTransformation 実装は既定で有効になっていません。 IClaimsTransformation 実装で要求を返還するとき、AddAuthentication を呼び出し、認証サービスを追加します。
public void ConfigureServices(IServiceCollection services) { services.AddTransient<IClaimsTransformation, ClaimsTransformer>(); services.AddAuthentication(IISServerDefaults.AuthenticationScheme); } public void Configure(IApplicationBuilder app) { app.UseAuthentication(); }
- Web パッケージ (単一ファイル) の配置はサポートされていません。
アウト プロセス ホスティング モデル
アウトプロセス ホスティング用にアプリを構成するには、プロジェクト ファイル ( .csproj
) で、<AspNetCoreHostingModel>
プロパティの値を OutOfProcess
に設定します。
<PropertyGroup>
<AspNetCoreHostingModel>OutOfProcess</AspNetCoreHostingModel>
</PropertyGroup>
インプロセス ホスティングは InProcess
で設定され、これが既定値です。
<AspNetCoreHostingModel>
の値では大文字と小文字が区別されないため、inprocess
と outofprocess
は有効な値となります。
IIS HTTP サーバー (IISHttpServer
) の代わりに、Kestrel サーバーが使用されます。
アウトプロセスの場合は、CreateDefaultBuilder
によって UseIISIntegration が呼び出され、次のことが行われます。
- ASP.NET Core モジュールの背後で実行するときにサーバーがリッスンする、ポートとベース パスを構成します。
- スタートアップ エラーをキャプチャするホストを構成します。
ホスティング モデルの変更
hostingModel
の設定が web.config
ファイル内で変更された場合 (「web.config
での構成」セクションを参照)、モジュールによって IIS 用のワーカー プロセスがリサイクルされます。
IIS Express の場合、モジュールによってワーカー プロセスのリサイクルは行われませんが、代わりに、現在の IIS Express プロセスの正常なシャットダウンがトリガーされます。 アプリに対して次の要求が出されると、IIS Express の新しいプロセスが生成されます。
プロセス名
Process.GetCurrentProcess().ProcessName
から、w3wp
/iisexpress
(インプロセス) または dotnet
(アウト プロセス) がレポートされます。
Windows 認証などの多くのネイティブなモジュールは、アクティブなままです。 ASP.NET Core モジュールでアクティブな IIS モジュールの詳細については、「ASP.NET Core での IIS モジュール」を参照してください。
ASP.NET Core モジュールでは次のことも行えます。
- ワーカー プロセスの環境変数を設定する
- 起動に関する問題をトラブルシューティングするために、Stdout 出力をファイル ストレージに記録する
- Windows 認証トークンを転送する
ASP.NET Core モジュール (ANCM) をインストールして使用する方法
ASP.NET Core モジュールのインストール手順については、「.NET Core ホスティング バンドルのインストール」を参照してください。 ASP.NET Core モジュールは、.NET のサポート対象リリースとの上位互換性および下位互換性があります。
破壊的変更とセキュリティ アドバイザリは、アナウンス リポジトリで報告されます。 ラベル フィルターを選択すると、特定のバージョンにアナウンスを限定できます。
web.config での構成
ASP.NET Core モジュールは、サイトの web.config ファイルの system.webServer
ノードの aspNetCore
セクションを使って構成します。
次に示す web.config
ファイルは、フレームワークに依存する展開用に発行されたもので、サイトの要求を処理するように ASP.NET Core モジュールを構成します。
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<location path="." inheritInChildApplications="false">
<system.webServer>
<handlers>
<add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModuleV2" resourceType="Unspecified" />
</handlers>
<aspNetCore processPath="dotnet"
arguments=".\MyApp.dll"
stdoutLogEnabled="false"
stdoutLogFile=".\logs\stdout"
hostingModel="inprocess" />
</system.webServer>
</location>
</configuration>
次の web.config は、自己完結型の展開用に発行されたものです。
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<location path="." inheritInChildApplications="false">
<system.webServer>
<handlers>
<add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModuleV2" resourceType="Unspecified" />
</handlers>
<aspNetCore processPath=".\MyApp.exe"
stdoutLogEnabled="false"
stdoutLogFile=".\logs\stdout"
hostingModel="inprocess" />
</system.webServer>
</location>
</configuration>
InheritInChildApplications プロパティは、false
に設定されます。これは、<location>
要素内で指定された設定が、アプリのサブディレクトリにあるアプリによって継承されないことを示します。
アプリが Azure App Service に対して展開されると、stdoutLogFile
パスは \\?\%home%\LogFiles\stdout
に設定されます。 パスは stdout ログを LogFiles
フォルダーに保存します。これは、サービスによって自動的に作成される場所です。
IIS サブアプリケーション構成の詳細については、「IIS を使用した Windows での ASP.NET Core のホスト」を参照してください。
aspNetCore 要素の属性
属性 | 説明 | Default |
---|---|---|
arguments |
省略可能な文字列属性。 processPath において指定されている実行可能ファイルへの引数です。 |
|
disableStartUpErrorPage |
省略可能な Boolean 属性です。 true の場合、502.5 - 処理エラー ページは抑制され、web.config で構成されている 502 状態コード ページが優先されます。 |
false |
forwardWindowsAuthToken |
省略可能な Boolean 属性です。 true の場合、トークンは、 |
true |
hostingModel |
省略可能な文字列属性。 ホスティング モデルをインプロセス ( |
InProcess inprocess |
processesPerApplication |
省略可能な整数属性 アプリごとにスピンアップすることができる processPath 設定内で指定したプロセスのインスタンス数が指定されます。 †インプロセス ホスティングの場合、値は 設定 |
既定値: 1 最小値: 1 最大値: 100 † |
processPath |
必須の文字列属性です。 HTTP 要求をリッスンするプロセスを起動する実行可能ファイルへのパスです。 相対パスがサポートされています。 パスが |
|
rapidFailsPerMinute |
省略可能な整数属性 processPath で指定されているプロセスが 1 分間にクラッシュできる回数を指定します。 この制限を超えた場合、モジュールは、1 分間の残りの間、プロセスの起動を停止します。 インプロセス ホスティングではサポートされていません。 |
既定値: 10 最小値: 0 最大値: 100 |
requestTimeout |
省略可能な期間属性。 %ASPNETCORE_PORT% でリッスンしているプロセスからの応答を ASP.NET Core モジュールが待機する期間を指定します。 ASP.NET Core 2.1 以降のリリースに付属する ASP.NET Core モジュールのバージョンでは、 インプロセス ホスティングには適用されません。 インプロセス ホスティングの場合、アプリによって要求が処理されるまでモジュールは待機します。 0 から 59 までが文字列の分セグメントと秒セグメントで有効な値となります。 分または秒の値に 60 を入れると 500 - Internal Server Error が出ます。 |
既定値: 00:02:00 最小値: 00:00:00 最大値: 360:00:00 |
shutdownTimeLimit |
省略可能な整数属性
|
既定値: 10 最小値: 0 最大値: 600 |
startupTimeLimit |
省略可能な整数属性 ポートでリッスンするプロセスを実行可能ファイルが開始するのをモジュールが待機する秒単位の期間です。 この制限時間を超えた場合、モジュールはプロセスを強制終了します。 "インプロセス" でホスティングしている場合: プロセスは再起動されておらず、rapidFailsPerMinute 設定が使用されていません。 "アウト プロセス" でホスティングしている場合: 最後のローリング分においてアプリが rapidFailsPerMinute 回だけ開始を失敗しているのでないかぎり、モジュールは、新しい要求を受け取るとプロセスの再起動を試み、それ以降に受信した要求に対してプロセスの再起動を試み続けます。 値 0 (ゼロ) は無限のタイムアウトと見なされません。 |
既定値: 120 最小値: 0 最大値: 3600 |
stdoutLogEnabled |
省略可能な Boolean 属性です。 true の場合、processPath で指定されているプロセスの stdout と stderr は、stdoutLogFile で指定されているファイルにリダイレクトされます。 |
false |
stdoutLogFile |
省略可能な文字列属性。 processPath で指定されているプロセスからの stdout と stderr がログに記録される相対ファイル パスまたは絶対ファイル パスを指定します。 相対パスの基準はサイトのルートです。 |
aspnetcore-stdout |
環境変数を設定する
processPath
属性で、プロセスに対する環境変数を指定できます。 <environmentVariables>
コレクション要素の <environmentVariable>
子要素で、環境変数を指定します。 このセクションで設定された環境変数は、システム環境変数より優先されます。
次の例では、web.config
内に 2 つの環境変数が設定されています。 ASPNETCORE_ENVIRONMENT
は、Development
に対するアプリの環境を構成します。 開発者は、アプリの例外をデバッグするときに開発者例外ページを強制的に読み込むため、web.config
ファイルでこの値を一時的に設定できます。 CONFIG_DIR
はユーザー定義の環境変数の例です。開発者はここに、アプリの構成ファイルを読み込むためのパスを形成するために起動時に値を読み取るコードを記述してあります。
<aspNetCore processPath="dotnet"
arguments=".\MyApp.dll"
stdoutLogEnabled="false"
stdoutLogFile=".\logs\stdout"
hostingModel="inprocess">
<environmentVariables>
<environmentVariable name="ASPNETCORE_ENVIRONMENT" value="Development" />
<environmentVariable name="CONFIG_DIR" value="f:\application_config" />
</environmentVariables>
</aspNetCore>
Note
web.config
内で環境を直接設定する代わりに、発行プロファイル (.pubxml
) またはプロジェクト ファイルに <EnvironmentName>
プロパティを含めることができます。 この方法では、プロジェクトが発行されるときに web.config
に環境が設定されます。
<PropertyGroup>
<EnvironmentName>Development</EnvironmentName>
</PropertyGroup>
警告
インターネットなどの信頼されていないネットワークにアクセスできないステージング サーバーやテスト サーバーでは、ASPNETCORE_ENVIRONMENT
環境変数を Development
に設定するだけです。
app_offline.htm
app_offline.htm
という名前のファイルがアプリのルート ディレクトリで検出された場合、ASP.NET Core モジュールはアプリを正常にシャットダウンし、受信要求の処理を停止することを試みます。 shutdownTimeLimit
で定義されている秒数が経過してもまだアプリが実行している場合、ASP.NET Core モジュールは実行中のプロセスを強制終了します。
app_offline.htm
ファイルが存在している間、ASP.NET Core モジュールは、app_offline.htm
ファイルの内容を返送することで、要求に応答します。 app_offline.htm
ファイルが削除されると、次の要求によってアプリが起動されます。
アウト プロセス ホスティング モデルを使用するときは、開いている接続があると、アプリがすぐにシャットダウンされない可能性があります。 たとえば、WebSocket 接続によってアプリのシャットダウンが遅れる可能性があります。
起動エラー ページ
インプロセス ホスティングでもアウト プロセス ホスティングでも、アプリの起動に失敗すると、カスタム エラー ページが生成されます。
ASP.NET Core モジュールが、インプロセスまたはアウト プロセスのどちらかの要求ハンドラーの検索に失敗した場合、500.0 - インプロセス/アウト プロセス ハンドラーの読み込みエラー状態コード ページが表示されます。
インプロセス ホスティングで、ASP.NET Core モジュールによるアプリの起動が失敗すると、500.30 - 開始エラー状態コード ページが表示されます。
アウト プロセス ホスティングで、ASP.NET Core モジュールがバックエンド プロセスの起動に失敗した場合、またはバックエンド プロセスは開始しても構成されているポートでのリッスンに失敗した場合は、502.5 処理エラー状態コード ページが表示されます。
このページを抑制して、既定の IIS 5xx 状態コード ページに戻すには、disableStartUpErrorPage
属性を使います。 カスタム エラー メッセージの構成方法について詳しくは、HTTP エラー <httpErrors>
に関するページをご覧ください。
ログの作成とリダイレクト
aspNetCore
要素の stdoutLogEnabled
属性および stdoutLogFile
属性が設定されている場合は、stdout および stderr コンソール出力が ASP.NET Core モジュールによってディスクにリダイレクトされます。 stdoutLogFile
パスのフォルダーは、ログ ファイルの作成時、モジュールによって作成されます。 アプリ プールは、ログが書き込まれる場所への書き込みアクセス権を持っている必要があります (書き込みアクセス許可を提供するには、IIS AppPool\<app_pool_name>
を使います)。
プロセスのリサイクル/再起動が発生しない場合、ログは循環されません。 ログが使用するディスク領域を制限するのは、ホストの役割です。
stdout ログの使用は、IIS でホストするときか、Visual Studio の開発時 IIS サポートを使用するとき、アプリの起動問題を解決する場合にのみ推奨されます。ローカル デバッグ時、IIS Express でアプリを実行している場合は推奨されません。
一般的なアプリ ログの目的には、stdout ログを使わないでください。 ASP.NET Core アプリでのルーチン ログの場合は、ログ ファイルのサイズを制限し、ログをローテーションするログ ライブラリを使います。 詳しくは、「サードパーティ製のログ プロバイダー」をご覧ください。
ログ ファイルの作成時には、タイムスタンプとファイルの拡張子が自動的に追加されます。 ログ ファイル名は、タイムスタンプ、プロセス ID、およびファイル拡張子 ( .log
) を stdoutLogFile
パスの最後のセグメント (通常は stdout
) にアンダースコアで区切って追加することで構成されます。 stdoutLogFile
パスが stdout
で終わっている場合、PID が 1934 で 2018 年 2 月 5 日の 19:42:32 に作成されたアプリのログのファイル名は、stdout_20180205194132_1934.log
になります。
stdoutLogEnabled
が false の場合は、アプリの起動時に発生するエラーがキャプチャされ、30 KB までイベント ログに出力されます。 起動後、すべての追加のログが破棄されます。
次のサンプルでは、aspNetCore
要素により相対パス .\log\
で stdout ログ記録が構成されます。 AppPool のユーザー identity に、指定されたパスへの書き込みアクセス許可があることを確認してください。
<aspNetCore processPath="dotnet"
arguments=".\MyApp.dll"
stdoutLogEnabled="true"
stdoutLogFile=".\logs\stdout"
hostingModel="inprocess">
</aspNetCore>
Azure App Service デプロイのためにアプリを公開するとき、Web SDK により stdoutLogFile
値が \\?\%home%\LogFiles\stdout
に設定されます。 Azure App Service でホストされるアプリの場合、%home
環境変数が事前定義されます。
ログ記録のフィルター ルールを作成するには、ASP.NET Core ログ記録のドキュメントの「コードでログ フィルター ルールを適用する」セクションを参照してください。
パス形式の詳細については、「Windows システムのファイル パス形式」を参照してください。
強化された診断ログ
ASP.NET Core モジュールは、強化された診断ログを提供するよう構成できます。 <handlerSettings>
要素を、web.config
内の <aspNetCore>
要素に追加します。 debugLevel
を TRACE
に設定すると、診断情報が再現性の高いものになります。
<aspNetCore processPath="dotnet"
arguments=".\MyApp.dll"
stdoutLogEnabled="false"
stdoutLogFile="\\?\%home%\LogFiles\stdout"
hostingModel="inprocess">
<handlerSettings>
<handlerSetting name="debugFile" value=".\logs\aspnetcore-debug.log" />
<handlerSetting name="debugLevel" value="FILE,TRACE" />
</handlerSettings>
</aspNetCore>
パスに含まれるフォルダー (前の例では logs
) は、ログ ファイルの作成時に、モジュールによって作成されます。 アプリ プールには、ログが書き込まれる場所への書き込みアクセス権が付与されている必要があります (書き込みアクセス許可を提供するには、IIS AppPool\{APP POOL NAME}
を使用します。ここで、プレースホルダー {APP POOL NAME}
はアプリ プール名です)。
デバッグ レベル (debugLevel
) 値には、レベルと場所の両方を含めることができます。
レベルは次のとおりです (情報量が少ないものから多いものへの順)。
- ERROR
- WARNING
- INFO
- TRACE
場所は次のとおりです (複数の場所を指定できます)。
- CONSOLE
- EVENTLOG
- ファイル
ハンドラー設定は、次の環境変数を使用して指定することもできます。
ASPNETCORE_MODULE_DEBUG_FILE
:デバッグ ログ ファイルのパス。 (既定値:aspnetcore-debug.log
)ASPNETCORE_MODULE_DEBUG
:デバッグ レベルの設定。
警告
配置内でデバッグ ログを、問題のトラブルシューティングに必要な時間よりも長く有効のままにしないでください。 ログのサイズは制限されていません。 デバッグ ログを有効のままにすると、使用可能なディスク領域が使い果たされ、サーバーまたはアプリ サービスがクラッシュする可能性があります。
web.config
ファイルでの aspNetCore
要素の例については、「web.config での構成」をご覧ください。
スタック サイズを変更する
"インプロセス ホスティング モデルを使用している場合にのみ適用されます。 "
web.config
で stackSize
の設定を使用してマネージド スタックのサイズを構成します (バイト単位)。 既定のサイズは 1,048,576 バイト (1 MB) です。
<aspNetCore processPath="dotnet"
arguments=".\MyApp.dll"
stdoutLogEnabled="false"
stdoutLogFile="\\?\%home%\LogFiles\stdout"
hostingModel="inprocess">
<handlerSettings>
<handlerSetting name="stackSize" value="2097152" />
</handlerSettings>
</aspNetCore>
プロキシの構成で HTTP プロトコルとペアリング トークンを使用する
アウト プロセス ホスティングにのみ適用されます。
ASP.NET Core モジュールと Kestrel の間に作成されるプロキシは、HTTP プロトコルを使います。 モジュールと Kestrel の間のトラフィックが、サーバーから離れた場所で傍受される危険はありません。
ペアリング トークンを使用すると、Kestrel によって受信される要求が IIS によってプロキシされたものであり、他のソースからのものでないことを保証できます。 ペアリング トークンは、モジュールによって作成されて、環境変数 (ASPNETCORE_TOKEN
) に設定されます。 ペアリング トークンはまた、プロキシされたすべての要求のヘッダー (MS-ASPNETCORE-TOKEN
) にも設定されます。 IIS ミドルウェアは、受信した各要求をチェックし、ペアリング トークン ヘッダーの値が環境変数の値と一致することを確認します。 トークンの値が一致しない場合、要求はログに記録され、拒否されます。 ペアリング トークン環境変数およびモジュールと Kestrel の間のトラフィックには、サーバーから離れた場所からアクセスすることはできません。 ペアリング トークンの値がわからなければ、攻撃者は IIS ミドルウェアのチェックをバイパスする要求を送信できません。
IIS 共有構成での ASP.NET Core モジュール
ASP.NET Core モジュールのインストーラーは、TrustedInstaller アカウントのアクセス許可を使って実行します。 ローカル システム アカウントには、IIS 共有構成によって使われる共有パスに対する変更アクセス許可がないため、インストーラーが共有上の applicationHost.config
ファイル内のモジュール設定を構成しようとすると、アクセス拒否エラーがスローされます。
IIS がインストールされている同じコンピューターで IIS 共有抗生を使用するとき、OPT_NO_SHARED_CONFIG_CHECK
パラメーターを 1
に設定して ASP.NET Core Hosting Bundle インストーラーを実行します。
dotnet-hosting-{VERSION}.exe OPT_NO_SHARED_CONFIG_CHECK=1
共有構成のパスが IIS をインストールしている同じコンピューター上にないときは、次の手順を実行します。
- IIS 共有構成を無効にします。
- インストーラーを実行します。
- 更新された
applicationHost.config
ファイルを共有にエクスポートします。 - IIS 共有構成を再び有効にします。
モジュールのバージョンとホスティング バンドル インストーラーのログ
インストールされている ASP.NET Core モジュールのバージョンを確認するには:
- ホスティング システム上で、
%windir%\System32\inetsrv
に移動します。 aspnetcore.dll
ファイルを見つけます。- ファイルを右クリックし、コンテキスト メニューの [プロパティ] を選びます。
- [詳細] タブを選びます。 [ファイル バージョン] と [製品バージョン] が、インストールされているモジュールのバージョンを表します。
モジュールに関するホスティング バンドル インストーラーのログは、C:\Users\%UserName%\AppData\Local\Temp
にあります。 ファイルの名前は dd_DotNetCoreWinSvrHosting__{TIMESTAMP}_000_AspNetCoreModule_x64.log
です。
モジュール、スキーマ、構成ファイルの場所
Module
IIS (x86/amd64) :
%windir%\System32\inetsrv\aspnetcore.dll
%windir%\SysWOW64\inetsrv\aspnetcore.dll
%ProgramFiles%\IIS\Asp.Net Core Module\V2\aspnetcorev2.dll
%ProgramFiles(x86)%\IIS\Asp.Net Core Module\V2\aspnetcorev2.dll
IIS Express (x86/amd64) :
%ProgramFiles%\IIS Express\aspnetcore.dll
%ProgramFiles(x86)%\IIS Express\aspnetcore.dll
%ProgramFiles%\IIS Express\Asp.Net Core Module\V2\aspnetcorev2.dll
%ProgramFiles(x86)%\IIS Express\Asp.Net Core Module\V2\aspnetcorev2.dll
Schema
IIS
%windir%\System32\inetsrv\config\schema\aspnetcore_schema.xml
%windir%\System32\inetsrv\config\schema\aspnetcore_schema_v2.xml
IIS Express
%ProgramFiles%\IIS Express\config\schema\aspnetcore_schema.xml
%ProgramFiles%\IIS Express\config\schema\aspnetcore_schema_v2.xml
構成
IIS
%windir%\System32\inetsrv\config\applicationHost.config
IIS Express
Visual Studio:
{APPLICATION ROOT}\.vs\config\applicationHost.config
iisexpress.exe CLI:
%USERPROFILE%\Documents\IISExpress\config\applicationhost.config
ファイルは、applicationHost.config
ファイルで aspnetcore
を検索することにより見つかります。
ASP.NET Core モジュール (ANCM) はネイティブな IIS モジュールであり、次のいずれかを目的として、IIS パイプラインにプラグインされます。
- IIS ワーカー プロセス (
w3wp.exe
) の内部で ASP.NET Core アプリをホストします。これは、インプロセス ホスティング モデルと呼ばれています。 - Kestrel サーバーを実行しているバックエンドの ASP.NET Core アプリに Web 要求を転送します。これは、アウト プロセス ホスティング モデルと呼ばれています。
サポートされている Windows バージョン:
- Windows 7 以降
- Windows Server 2008 R2 以降
インプロセス ホスティングの場合、モジュールでは IIS HTTP サーバー (IISHttpServer
) と呼ばれる IIS 用のインプロセス サーバー実装が使用されます。
アウト プロセスでホストする場合、モジュールは Kestrel に対してのみ機能します。 このモジュールは HTTP.sys では機能しません。
ホスティング モデル
インプロセス ホスティング モデル
アプリに対してインプロセス ホスティングを構成するには、そのアプリのプロジェクト ファイルに <AspNetCoreHostingModel>
プロパティを追加して、値を InProcess
に設定します。(アウト プロセス ホスティングは OutOfProcess
を使用して設定します)。
<PropertyGroup>
<AspNetCoreHostingModel>InProcess</AspNetCoreHostingModel>
</PropertyGroup>
.NET Framework をターゲットにする ASP.NET Core アプリではインプロセス ホスティング モデルはサポートされていません。
<AspNetCoreHostingModel>
の値では大文字と小文字が区別されないため、inprocess
と outofprocess
は有効な値となります。
<AspNetCoreHostingModel>
プロパティがファイルに存在しない場合、既定値は OutOfProcess
です。
インプロセスでホストする場合は、次の特性が適用されます。
Kestrel サーバーの代わりに、IIS HTTP サーバー (
IISHttpServer
) が使用されます。 インプロセスの場合、CreateDefaultBuilder により UseIIS が呼び出され、次が実行されます。IISHttpServer
を登録します。- ASP.NET Core モジュールの背後で実行するときにサーバーがリッスンする、ポートとベース パスを構成します。
- スタートアップ エラーをキャプチャするホストを構成します。
requestTimeout 属性 は、インプロセス ホスティングには適用されません。
アプリ プールをアプリ間で共有することはサポートされていません。 アプリごとに 1 つのアプリ プールを使用します。
Web 配置を使用したとき、または app_offline.htm ファイルを手動で配置内に置いたときには、開いている接続があると、アプリがすぐにシャットダウンされない場合があります。 たとえば、WebSocket 接続では、アプリのシャットダウンが遅れる可能性があります。
アプリとインストールされているランタイム (x64 または x86) のアーキテクチャ (ビット) は、アプリ プールのアーキテクチャと一致する必要があります。
クライアントの切断が検出されます。 クライアントが切断されると、HttpContext.RequestAborted キャンセル トークンが取り消されます。
ASP.NET Core 2.2.1 以前の場合、GetCurrentDirectory は、アプリのディレクトリではなく、IIS によって開始されたプロセスのワーカー ディレクトリを返します (たとえば、w3wp.exe に対して C:\Windows\System32\inetsrv)。
アプリの現在のディレクトリを設定するサンプル コードについては、「CurrentDirectoryHelpers クラス」を参照してください。
SetCurrentDirectory
メソッドを呼び出します。 GetCurrentDirectory の後続の呼び出しによって、アプリのディレクトリが指定されます。インプロセス ホスティングの場合、ユーザーを初期化するために内部で AuthenticateAsync が呼び出されることはありません。 そのため、認証のたびに要求を変換するための IClaimsTransformation 実装は既定で有効になっていません。 IClaimsTransformation 実装で要求を返還するとき、AddAuthentication を呼び出し、認証サービスを追加します。
public void ConfigureServices(IServiceCollection services) { services.AddTransient<IClaimsTransformation, ClaimsTransformer>(); services.AddAuthentication(IISServerDefaults.AuthenticationScheme); } public void Configure(IApplicationBuilder app) { app.UseAuthentication(); }
アウト プロセス ホスティング モデル
アウト プロセス ホスティング用のアプリを構成するには、プロジェクト ファイルで次の方法のいずれかを使用します。
<AspNetCoreHostingModel>
プロパティは指定しないでください。<AspNetCoreHostingModel>
プロパティがファイルに存在しない場合、既定値はOutOfProcess
です。<AspNetCoreHostingModel>
プロパティの値をOutOfProcess
に設定します (インプロセス ホスティングはInProcess
で設定されます)。
<PropertyGroup>
<AspNetCoreHostingModel>OutOfProcess</AspNetCoreHostingModel>
</PropertyGroup>
この値では大文字と小文字が区別されないため、inprocess
と outofprocess
は有効な値となります。
IIS HTTP サーバー (IISHttpServer
) の代わりに、Kestrel サーバーが使用されます。
アウトプロセスの場合、CreateDefaultBuilder により UseIISIntegration が呼び出され、次が実行されます。
- ASP.NET Core モジュールの背後で実行するときにサーバーがリッスンする、ポートとベース パスを構成します。
- スタートアップ エラーをキャプチャするホストを構成します。
ホスティング モデルの変更
hostingModel
設定が web.config ファイル内で変更された場合 (「web.config での構成」セクションを参照)、モジュールによって IIS 用のワーカー プロセスがリサイクルされます。
IIS Express の場合、モジュールによってワーカー プロセスのリサイクルは行われませんが、代わりに、現在の IIS Express プロセスの正常なシャットダウンがトリガーされます。 アプリに対して次の要求が出されると、IIS Express の新しいプロセスが生成されます。
プロセス名
Process.GetCurrentProcess().ProcessName
から、w3wp
/iisexpress
(インプロセス) または dotnet
(アウト プロセス) がレポートされます。
Windows 認証などの多くのネイティブなモジュールは、アクティブなままです。 ASP.NET Core モジュールでアクティブな IIS モジュールの詳細については、「ASP.NET Core での IIS モジュール」を参照してください。
ASP.NET Core モジュールでは次のことも行えます。
- ワーカー プロセスの環境変数を設定する
- 起動に関する問題をトラブルシューティングするために、Stdout 出力をファイル ストレージに記録する
- Windows 認証トークンを転送する
ASP.NET Core モジュール (ANCM) をインストールして使用する方法
ASP.NET Core モジュールのインストール手順については、「.NET Core ホスティング バンドルのインストール」を参照してください。 ASP.NET Core モジュールは、.NET のサポート対象リリースとの上位互換性および下位互換性があります。
破壊的変更とセキュリティ アドバイザリは、アナウンス リポジトリで報告されます。 ラベル フィルターを選択すると、特定のバージョンにアナウンスを限定できます。
web.config での構成
ASP.NET Core モジュールは、サイトの web.config ファイルの system.webServer
ノードの aspNetCore
セクションを使って構成します。
次に示す web.config ファイルは、フレームワークに依存する展開用に発行されたもので、サイトの要求を処理するように ASP.NET Core モジュールを構成します。
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<location path="." inheritInChildApplications="false">
<system.webServer>
<handlers>
<add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModuleV2" resourceType="Unspecified" />
</handlers>
<aspNetCore processPath="dotnet"
arguments=".\MyApp.dll"
stdoutLogEnabled="false"
stdoutLogFile=".\logs\stdout"
hostingModel="inprocess" />
</system.webServer>
</location>
</configuration>
次の web.config は、自己完結型の展開用に発行されたものです。
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<location path="." inheritInChildApplications="false">
<system.webServer>
<handlers>
<add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModuleV2" resourceType="Unspecified" />
</handlers>
<aspNetCore processPath=".\MyApp.exe"
stdoutLogEnabled="false"
stdoutLogFile=".\logs\stdout"
hostingModel="inprocess" />
</system.webServer>
</location>
</configuration>
InheritInChildApplications プロパティは、false
に設定されます。これは、<location> 要素内で指定された設定が、アプリのサブディレクトリにあるアプリによって継承されないことを示します。
アプリが Azure App Service に対して展開されると、stdoutLogFile
パスは \\?\%home%\LogFiles\stdout
に設定されます。 パスは stdout ログを LogFiles フォルダーに保存します。これは、サービスによって自動的に作成される場所です。
IIS サブアプリケーション構成の詳細については、「IIS を使用した Windows での ASP.NET Core のホスト」を参照してください。
aspNetCore 要素の属性
属性 | 説明 | Default |
---|---|---|
arguments |
省略可能な文字列属性。
|
|
disableStartUpErrorPage |
省略可能な Boolean 属性です。 true の場合、502.5 - 処理エラー ページは抑制され、web.config で構成されている 502 状態コード ページが優先されます。 |
false |
forwardWindowsAuthToken |
省略可能な Boolean 属性です。 true の場合、トークンは、%ASPNETCORE_PORT% でリッスンしている子プロセスに、要求ごとの 'MS-ASPNETCORE-WINAUTHTOKEN' ヘッダーとして転送されます。 要求ごとのこのトークンで CloseHandle を呼び出すのは、そのプロセスの役割です。 |
true |
hostingModel |
省略可能な文字列属性。 ホスティング モデルをインプロセス ( |
OutOfProcess outofprocess |
processesPerApplication |
省略可能な整数属性 アプリごとにスピンアップすることができる †インプロセス ホスティングの場合、値は 設定 |
既定値: 1 最小値: 1 最大値: 100 † |
processPath |
必須の文字列属性です。 HTTP 要求をリッスンするプロセスを起動する実行可能ファイルへのパスです。 相対パスがサポートされています。 パスが |
|
rapidFailsPerMinute |
省略可能な整数属性
インプロセス ホスティングではサポートされていません。 |
既定値: 10 最小値: 0 最大値: 100 |
requestTimeout |
省略可能な期間属性。 %ASPNETCORE_PORT% でリッスンしているプロセスからの応答を ASP.NET Core モジュールが待機する期間を指定します。 ASP.NET Core 2.1 以降のリリースに付属する ASP.NET Core モジュールのバージョンでは、 インプロセス ホスティングには適用されません。 インプロセス ホスティングの場合、アプリによって要求が処理されるまでモジュールは待機します。 0 から 59 までが文字列の分セグメントと秒セグメントで有効な値となります。 分または秒の値に 60 を入れると 500 - Internal Server Error が出ます。 |
既定値: 00:02:00 最小値: 00:00:00 最大値: 360:00:00 |
shutdownTimeLimit |
省略可能な整数属性
|
既定値: 10 最小値: 0 最大値: 600 |
startupTimeLimit |
省略可能な整数属性 ポートでリッスンするプロセスを実行可能ファイルが開始するのをモジュールが待機する秒単位の期間です。 この制限時間を超えた場合、モジュールはプロセスを強制終了します。 "インプロセス" でホスティングしている場合: プロセスは再起動されておらず、 "アウト プロセス" でホスティングしている場合: 最後のローリング分においてアプリが 値 0 (ゼロ) は無限のタイムアウトと見なされません。 |
既定値: 120 最小値: 0 最大値: 3600 |
stdoutLogEnabled |
省略可能な Boolean 属性です。 true の場合、 |
false |
stdoutLogFile |
省略可能な文字列属性。
|
aspnetcore-stdout |
環境変数の設定
processPath
属性で、プロセスに対する環境変数を指定できます。 <environmentVariables>
コレクション要素の <environmentVariable>
子要素で、環境変数を指定します。 このセクションで設定された環境変数は、システム環境変数より優先されます。
次の例では、2 つの環境変数を設定しています。 ASPNETCORE_ENVIRONMENT
は、Development
に対するアプリの環境を構成します。 開発者は、アプリの例外をデバッグするときに開発者例外ページを強制的に読み込むため、web.config
ファイルでこの値を一時的に設定できます。 CONFIG_DIR
はユーザー定義の環境変数の例です。開発者はここに、アプリの構成ファイルを読み込むためのパスを形成するために起動時に値を読み取るコードを記述してあります。
<aspNetCore processPath="dotnet"
arguments=".\MyApp.dll"
stdoutLogEnabled="false"
stdoutLogFile=".\logs\stdout"
hostingModel="inprocess">
<environmentVariables>
<environmentVariable name="ASPNETCORE_ENVIRONMENT" value="Development" />
<environmentVariable name="CONFIG_DIR" value="f:\application_config" />
</environmentVariables>
</aspNetCore>
Note
web.config
内で環境を直接設定する代わりに、発行プロファイル (.pubxml) またはプロジェクト ファイルに <EnvironmentName>
プロパティを含めることができます。 この方法では、プロジェクトが発行されるときに web.config
に環境が設定されます。
<PropertyGroup>
<EnvironmentName>Development</EnvironmentName>
</PropertyGroup>
警告
インターネットなどの信頼されていないネットワークにアクセスできないステージング サーバーやテスト サーバーでは、ASPNETCORE_ENVIRONMENT
環境変数を Development
に設定するだけです。
app_offline.htm
app_offline.htm
という名前のファイルがアプリのルート ディレクトリで検出された場合、ASP.NET Core モジュールはアプリを正常にシャットダウンし、受信要求の処理を停止することを試みます。 shutdownTimeLimit
で定義されている秒数が経過してもまだアプリが実行している場合、ASP.NET Core モジュールは実行中のプロセスを強制終了します。
app_offline.htm
ファイルが存在している間、ASP.NET Core モジュールは、app_offline.htm
ファイルの内容を返送することで、要求に応答します。 app_offline.htm
ファイルが削除されると、次の要求によってアプリが起動されます。
アウト プロセス ホスティング モデルを使用するときは、開いている接続があると、アプリがすぐにシャットダウンされない可能性があります。 たとえば、WebSocket 接続では、アプリのシャットダウンが遅れる可能性があります。
起動エラー ページ
インプロセス ホスティングでもアウト プロセス ホスティングでも、アプリの起動に失敗すると、カスタム エラー ページが生成されます。
ASP.NET Core モジュールが、インプロセスまたはアウト プロセスのどちらかの要求ハンドラーの検索に失敗した場合、500.0 - インプロセス/アウト プロセス ハンドラーの読み込みエラー状態コード ページが表示されます。
インプロセス ホスティングで、ASP.NET Core モジュールによるアプリの起動が失敗すると、500.30 - 開始エラー状態コード ページが表示されます。
アウト プロセス ホスティングで、ASP.NET Core モジュールがバックエンド プロセスの起動に失敗した場合、またはバックエンド プロセスは開始しても構成されているポートでのリッスンに失敗した場合は、502.5 処理エラー状態コード ページが表示されます。
このページを抑制して、既定の IIS 5xx 状態コード ページに戻すには、disableStartUpErrorPage
属性を使います。 カスタム エラー メッセージの構成方法について詳しくは、HTTP エラー <httpErrors> に関するページをご覧ください。
ログの作成とリダイレクト
aspNetCore
要素の stdoutLogEnabled
属性および stdoutLogFile
属性が設定されている場合は、stdout および stderr コンソール出力が ASP.NET Core モジュールによってディスクにリダイレクトされます。 stdoutLogFile
パスのフォルダーは、ログ ファイルの作成時、モジュールによって作成されます。 アプリ プールには、ログが書き込まれる場所への書き込みアクセス権が付与されている必要があります (書き込みアクセス許可を提供するには、IIS AppPool\{APP POOL NAME}
を使用します。ここで、プレースホルダー {APP POOL NAME}
はアプリ プール名です)。
プロセスのリサイクル/再起動が発生しない場合、ログは循環されません。 ログが使用するディスク領域を制限するのは、ホストの役割です。
stdout ログの使用は、IIS でホストするときか、Visual Studio の開発時 IIS サポートを使用するとき、アプリの起動問題を解決する場合にのみ推奨されます。ローカル デバッグ時、IIS Express でアプリを実行している場合は推奨されません。
一般的なアプリ ログの目的には、stdout ログを使わないでください。 ASP.NET Core アプリでのルーチン ログの場合は、ログ ファイルのサイズを制限し、ログをローテーションするログ ライブラリを使います。 詳しくは、「サードパーティ製のログ プロバイダー」をご覧ください。
ログ ファイルの作成時には、タイムスタンプとファイルの拡張子が自動的に追加されます。 ログ ファイル名は、タイムスタンプ、プロセス ID、およびファイル拡張子 ( .log
) を stdoutLogFile
パスの最後のセグメント (通常は stdout
) にアンダースコアで区切って追加することで構成されます。 stdoutLogFile
パスが stdout
で終わっている場合、PID が 1934 で 2018 年 2 月 5 日の 19:42:32 に作成されたアプリのログのファイル名は、stdout_20180205194132_1934.log
になります。
stdoutLogEnabled
が false の場合は、アプリの起動時に発生するエラーがキャプチャされ、30 KB までイベント ログに出力されます。 起動後、すべての追加のログが破棄されます。
次のサンプルでは、aspNetCore
要素により相対パス .\log\
で stdout ログ記録が構成されます。 アプリ プールのユーザー identity に、指定したパスへの書き込みアクセス許可があることを確認します。
<aspNetCore processPath="dotnet"
arguments=".\MyApp.dll"
stdoutLogEnabled="true"
stdoutLogFile=".\logs\stdout"
hostingModel="inprocess">
</aspNetCore>
Azure App Service デプロイのためにアプリを公開するとき、Web SDK により stdoutLogFile
値が \\?\%home%\LogFiles\stdout
に設定されます。 Azure App Service でホストされるアプリの場合、%home
環境変数が事前定義されます。
パス形式の詳細については、「Windows システムのファイル パス形式」を参照してください。
強化された診断ログ
ASP.NET Core モジュールは、強化された診断ログを提供するよう構成できます。 <handlerSettings>
要素を、web.config
内の <aspNetCore>
要素に追加します。 debugLevel
を TRACE
に設定すると、診断情報が再現性の高いものになります。
<aspNetCore processPath="dotnet"
arguments=".\MyApp.dll"
stdoutLogEnabled="false"
stdoutLogFile="\\?\%home%\LogFiles\stdout"
hostingModel="inprocess">
<handlerSettings>
<handlerSetting name="debugFile" value=".\logs\aspnetcore-debug.log" />
<handlerSetting name="debugLevel" value="FILE,TRACE" />
</handlerSettings>
</aspNetCore>
<handlerSetting>
値に提供されるパスのフォルダー (前の例では logs
) がこのモジュールによって自動的に作成されることはなく、デプロイに事前に存在する必要があります。 アプリ プールには、ログが書き込まれる場所への書き込みアクセス権が付与されている必要があります (書き込みアクセス許可を提供するには、IIS AppPool\{APP POOL NAME}
を使用します。ここで、プレースホルダー {APP POOL NAME}
はアプリ プール名です)。
デバッグ レベル (debugLevel
) 値には、レベルと場所の両方を含めることができます。
レベルは次のとおりです (情報量が少ないものから多いものへの順)。
- ERROR
- WARNING
- INFO
- TRACE
場所は次のとおりです (複数の場所を指定できます)。
- CONSOLE
- EVENTLOG
- ファイル
ハンドラー設定は、次の環境変数を使用して指定することもできます。
ASPNETCORE_MODULE_DEBUG_FILE
:デバッグ ログ ファイルのパス。 (既定値:aspnetcore-debug.log
)ASPNETCORE_MODULE_DEBUG
:デバッグ レベルの設定。
警告
配置内でデバッグ ログを、問題のトラブルシューティングに必要な時間よりも長く有効のままにしないでください。 ログのサイズは制限されていません。 デバッグ ログを有効のままにすると、使用可能なディスク領域が使い果たされ、サーバーまたはアプリ サービスがクラッシュする可能性があります。
web.config
ファイルでの aspNetCore
要素の例については、「web.config での構成」をご覧ください。
プロキシの構成で HTTP プロトコルとペアリング トークンを使用する
アウト プロセス ホスティングにのみ適用されます。
ASP.NET Core モジュールと Kestrel の間に作成されるプロキシは、HTTP プロトコルを使います。 モジュールと Kestrel の間のトラフィックが、サーバーから離れた場所で傍受される危険はありません。
ペアリング トークンを使用すると、Kestrel によって受信される要求が IIS によってプロキシされたものであり、他のソースからのものでないことを保証できます。 ペアリング トークンは、モジュールによって作成されて、環境変数 (ASPNETCORE_TOKEN
) に設定されます。 ペアリング トークンはまた、プロキシされたすべての要求のヘッダー (MS-ASPNETCORE-TOKEN
) にも設定されます。 IIS ミドルウェアは、受信した各要求をチェックし、ペアリング トークン ヘッダーの値が環境変数の値と一致することを確認します。 トークンの値が一致しない場合、要求はログに記録され、拒否されます。 ペアリング トークン環境変数およびモジュールと Kestrel の間のトラフィックには、サーバーから離れた場所からアクセスすることはできません。 ペアリング トークンの値がわからなければ、攻撃者は IIS ミドルウェアのチェックをバイパスする要求を送信できません。
IIS 共有構成での ASP.NET Core モジュール
ASP.NET Core モジュールのインストーラーは、TrustedInstaller
アカウントのアクセス許可を使って実行します。 ローカル システム アカウントには、IIS 共有構成によって使われる共有パスに対する変更アクセス許可がないため、インストーラーが共有上の applicationHost.config
ファイル内のモジュール設定を構成しようとすると、アクセス拒否エラーがスローされます。
IIS がインストールされている同じコンピューターで IIS 共有抗生を使用するとき、OPT_NO_SHARED_CONFIG_CHECK
パラメーターを 1
に設定して ASP.NET Core Hosting Bundle インストーラーを実行します。
dotnet-hosting-{VERSION}.exe OPT_NO_SHARED_CONFIG_CHECK=1
共有構成のパスが IIS をインストールしている同じコンピューター上にないときは、次の手順を実行します。
- IIS 共有構成を無効にします。
- インストーラーを実行します。
- 更新された
applicationHost.config
ファイルを共有にエクスポートします。 - IIS 共有構成を再び有効にします。
モジュールのバージョンとホスティング バンドル インストーラーのログ
インストールされている ASP.NET Core モジュールのバージョンを確認するには:
- ホスティング システム上で、
%windir%\System32\inetsrv
に移動します。 aspnetcore.dll
ファイルを見つけます。- ファイルを右クリックし、コンテキスト メニューの [プロパティ] を選びます。
- [詳細] タブを選びます。 [ファイル バージョン] と [製品バージョン] が、インストールされているモジュールのバージョンを表します。
モジュールに関するホスティング バンドル インストーラーのログは、C:\\Users\\%UserName%\\AppData\\Local\\Temp
にあります。 ファイルの名前は dd_DotNetCoreWinSvrHosting__\{TIMESTAMP}_000_AspNetCoreModule_x64.log
です。プレースホルダー {TIMESTAMP}
はタイムスタンプです。
モジュール、スキーマ、構成ファイルの場所
Module
IIS (x86/amd64) :
%windir%\System32\inetsrv\aspnetcore.dll
%windir%\SysWOW64\inetsrv\aspnetcore.dll
%ProgramFiles%\IIS\Asp.Net Core Module\V2\aspnetcorev2.dll
%ProgramFiles(x86)%\IIS\Asp.Net Core Module\V2\aspnetcorev2.dll
IIS Express (x86/amd64) :
%ProgramFiles%\IIS Express\aspnetcore.dll
%ProgramFiles(x86)%\IIS Express\aspnetcore.dll
%ProgramFiles%\IIS Express\Asp.Net Core Module\V2\aspnetcorev2.dll
%ProgramFiles(x86)%\IIS Express\Asp.Net Core Module\V2\aspnetcorev2.dll
Schema
IIS
%windir%\System32\inetsrv\config\schema\aspnetcore_schema.xml
%windir%\System32\inetsrv\config\schema\aspnetcore_schema_v2.xml
IIS Express
%ProgramFiles%\IIS Express\config\schema\aspnetcore_schema.xml
%ProgramFiles%\IIS Express\config\schema\aspnetcore_schema_v2.xml
構成
IIS
%windir%\System32\inetsrv\config\applicationHost.config
IIS Express
Visual Studio:
{APPLICATION ROOT}\.vs\config\applicationHost.config
iisexpress.exe CLI:
%USERPROFILE%\Documents\IISExpress\config\applicationhost.config
ファイルは、applicationHost.config
ファイルで aspnetcore
を検索することにより見つかります。
ASP.NET Core モジュール (ANCM) は、ネイティブな IIS モジュールであり、バックエンドの ASP.NET Core アプリに Web 要求を転送するために IIS パイプラインにプラグインされます。
サポートされている Windows バージョン:
- Windows 7 以降
- Windows Server 2008 R2 以降
モジュールは、Kestrel に対してのみ機能します。 モジュールは HTTP.sys と互換性はありません。
ASP.NET Core アプリは IIS ワーカー プロセスとは独立したプロセスで実行されるため、モジュールもプロセス管理を処理します。 モジュールは、最初の要求を受信したときに ASP.NET Core アプリのプロセスを開始し、プロセスがクラッシュした場合はアプリを再起動します。 この動作は、IIS のインプロセスで実行され、WAS (Windows プロセス アクティブ化サービス) によって管理される ASP.NET 4.x アプリと基本的に同じです。
次の図は、IIS (ASP.NET Core モジュール) とアプリの間のリレーションシップを示しています。
要求は、Web からカーネル モードの HTTP.sys ドライバーに到着します。 ドライバーは、Web サイトの構成ポート (通常は 80 (HTTP) または 443 (HTTPS)) で IIS への要求をルーティングします。 モジュールでは、アプリのランダムなポート (ポート 80 または 443 ではありません) で Kestrel に要求が転送されます。
モジュールによってスタートアップ時に環境変数を介してポートが指定されると、IIS 統合ミドルウェアによって http://localhost:{port}
をリッスンするようにサーバーが構成されます。 追加のチェックが実行され、モジュールから発生していない要求は拒否されます。 モジュールでは HTTPS 転送がサポートされていないため、要求は HTTPS を介して IIS によって受信された場合でも、HTTP を介して転送されます。
Kestrel によってモジュールから要求が取り込まれた後、その要求は ASP.NET Core ミドルウェア パイプラインにプッシュされます。 ミドルウェア パイプラインは要求を処理し、HttpContext
インスタンスとしてアプリのロジックに渡します。 IIS 統合によって追加されたミドルウェアでは、Kestrel への要求の転送を考慮して、スキーム、リモート IP、およびパスベースが更新されます。 アプリの応答が IIS に戻され、IIS はその応答を、要求を開始した HTTP クライアントに返します。
Windows 認証などの多くのネイティブなモジュールは、アクティブなままです。 ASP.NET Core モジュールでアクティブな IIS モジュールの詳細については、「ASP.NET Core での IIS モジュール」を参照してください。
ASP.NET Core モジュールでは次のことも行えます。
- ワーカー プロセスの環境変数を設定する
- 起動に関する問題をトラブルシューティングするために、Stdout 出力をファイル ストレージに記録する
- Windows 認証トークンを転送する
ASP.NET Core モジュール (ANCM) をインストールして使用する方法
ASP.NET Core モジュールのインストール手順については、「.NET Core ホスティング バンドルのインストール」を参照してください。
web.config での構成
ASP.NET Core モジュールは、サイトの web.config ファイルの system.webServer
ノードの aspNetCore
セクションを使って構成します。
次に示す web.config ファイルは、フレームワークに依存する展開用に発行されたもので、サイトの要求を処理するように ASP.NET Core モジュールを構成します。
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<system.webServer>
<handlers>
<add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModule" resourceType="Unspecified" />
</handlers>
<aspNetCore processPath="dotnet"
arguments=".\MyApp.dll"
stdoutLogEnabled="false"
stdoutLogFile=".\logs\stdout" />
</system.webServer>
</configuration>
次の web.config は、自己完結型の展開用に発行されたものです。
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<system.webServer>
<handlers>
<add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModule" resourceType="Unspecified" />
</handlers>
<aspNetCore processPath=".\MyApp.exe"
stdoutLogEnabled="false"
stdoutLogFile=".\logs\stdout" />
</system.webServer>
</configuration>
アプリが Azure App Service に対して展開されると、stdoutLogFile
パスは \\?\%home%\LogFiles\stdout
に設定されます。 パスは stdout ログを LogFiles フォルダーに保存します。これは、サービスによって自動的に作成される場所です。
IIS サブアプリケーション構成の詳細については、「IIS を使用した Windows での ASP.NET Core のホスト」を参照してください。
aspNetCore 要素の属性
属性 | 説明 | Default |
---|---|---|
arguments |
省略可能な文字列属性。 processPath において指定されている実行可能ファイルへの引数です。 |
|
disableStartUpErrorPage |
省略可能な Boolean 属性です。 true の場合、502.5 - 処理エラー ページは抑制され、web.config で構成されている 502 状態コード ページが優先されます。 |
false |
forwardWindowsAuthToken |
省略可能な Boolean 属性です。 true の場合、トークンは、%ASPNETCORE_PORT% でリッスンしている子プロセスに、要求ごとの 'MS-ASPNETCORE-WINAUTHTOKEN' ヘッダーとして転送されます。 要求ごとのこのトークンで CloseHandle を呼び出すのは、そのプロセスの役割です。 |
true |
processesPerApplication |
省略可能な整数属性 アプリごとにスピンアップすることができる processPath 設定内で指定したプロセスのインスタンス数が指定されます。 設定 |
既定値: 1 最小値: 1 最大値: 100 |
processPath |
必須の文字列属性です。 HTTP 要求をリッスンするプロセスを起動する実行可能ファイルへのパスです。 相対パスがサポートされています。 パスが |
|
rapidFailsPerMinute |
省略可能な整数属性 processPath で指定されているプロセスが 1 分間にクラッシュできる回数を指定します。 この制限を超えた場合、モジュールは、1 分間の残りの間、プロセスの起動を停止します。 |
既定値: 10 最小値: 0 最大値: 100 |
requestTimeout |
省略可能な期間属性。 %ASPNETCORE_PORT% でリッスンしているプロセスからの応答を ASP.NET Core モジュールが待機する期間を指定します。 ASP.NET Core 2.1 以降のリリースに付属する ASP.NET Core モジュールのバージョンでは、 |
既定値: 00:02:00 最小値: 00:00:00 最大値: 360:00:00 |
shutdownTimeLimit |
省略可能な整数属性
|
既定値: 10 最小値: 0 最大値: 600 |
startupTimeLimit |
省略可能な整数属性 ポートでリッスンするプロセスを実行可能ファイルが開始するのをモジュールが待機する秒単位の期間です。 この制限時間を超えた場合、モジュールはプロセスを強制終了します。 最後のローリング分においてアプリが rapidFailsPerMinute 回だけ開始を失敗しているのでないかぎり、モジュールは、新しい要求を受け取るとプロセスの再起動を試み、それ以降に受信した要求に対してプロセスの再起動を試み続けます。 値 0 (ゼロ) は無限のタイムアウトと見なされません。 |
既定値: 120 最小値: 0 最大値: 3600 |
stdoutLogEnabled |
省略可能な Boolean 属性です。 true の場合、processPath で指定されているプロセスの stdout と stderr は、stdoutLogFile で指定されているファイルにリダイレクトされます。 |
false |
stdoutLogFile |
省略可能な文字列属性。 processPath で指定されているプロセスからの stdout と stderr がログに記録される相対ファイル パスまたは絶対ファイル パスを指定します。 相対パスの基準はサイトのルートです。 |
aspnetcore-stdout |
環境変数の設定
processPath
属性で、プロセスに対する環境変数を指定できます。 <environmentVariables>
コレクション要素の <environmentVariable>
子要素で、環境変数を指定します。
警告
このセクションで設定した環境変数は、同じ名前を使って設定したシステム環境変数と競合します。 web.config ファイルと Windows のシステム レベルの両方で 1 つの環境変数が設定されている場合、web.config ファイルからの値がシステム環境変数の値に追加されるため (例: ASPNETCORE_ENVIRONMENT: Development;Development
)、アプリが起動できなくなります。
次の例では、2 つの環境変数を設定しています。 ASPNETCORE_ENVIRONMENT
は、Development
に対するアプリの環境を構成します。 開発者は、アプリの例外をデバッグするときに開発者例外ページを強制的に読み込むため、web.config ファイルでこの値を一時的に設定できます。 CONFIG_DIR
はユーザー定義の環境変数の例です。開発者はここに、アプリの構成ファイルを読み込むためのパスを形成するために起動時に値を読み取るコードを記述してあります。
<aspNetCore processPath="dotnet"
arguments=".\MyApp.dll"
stdoutLogEnabled="false"
stdoutLogFile="\\?\%home%\LogFiles\stdout">
<environmentVariables>
<environmentVariable name="ASPNETCORE_ENVIRONMENT" value="Development" />
<environmentVariable name="CONFIG_DIR" value="f:\application_config" />
</environmentVariables>
</aspNetCore>
警告
インターネットなどの信頼されていないネットワークにアクセスできないステージング サーバーやテスト サーバーでは、ASPNETCORE_ENVIRONMENT
環境変数を Development
に設定するだけです。
app_offline.htm
app_offline.htm
という名前のファイルがアプリのルート ディレクトリで検出された場合、ASP.NET Core モジュールはアプリを正常にシャットダウンし、受信要求の処理を停止することを試みます。 shutdownTimeLimit
で定義されている秒数が経過してもまだアプリが実行している場合、ASP.NET Core モジュールは実行中のプロセスを強制終了します。
app_offline.htm
ファイルが存在している間、ASP.NET Core モジュールは、app_offline.htm
ファイルの内容を返送することで、要求に応答します。 app_offline.htm
ファイルが削除されると、次の要求によってアプリが起動されます。
起動エラー ページ
ASP.NET Core モジュールが、バックエンド プロセスの起動に失敗した場合、またはバックエンド プロセスは開始しても構成されているポートでのリッスンに失敗した場合は、502.5 処理エラー状態コード ページが表示されます。 このページを抑制して、既定の IIS 502 状態コード ページに戻すには、disableStartUpErrorPage
属性を使います。 カスタム エラー メッセージの構成方法について詳しくは、HTTP エラー <httpErrors> に関するページをご覧ください。
ログの作成とリダイレクト
aspNetCore
要素の stdoutLogEnabled
属性および stdoutLogFile
属性が設定されている場合は、stdout および stderr コンソール出力が ASP.NET Core モジュールによってディスクにリダイレクトされます。 stdoutLogFile
パスのフォルダーは、ログ ファイルの作成時、モジュールによって作成されます。 アプリ プールは、ログが書き込まれる場所への書き込みアクセス権を持っている必要があります (書き込みアクセス許可を提供するには、IIS AppPool\<app_pool_name>
を使います)。
プロセスのリサイクル/再起動が発生しない場合、ログは循環されません。 ログが使用するディスク領域を制限するのは、ホストの役割です。
stdout ログの使用は、IIS でホストするときか、Visual Studio の開発時 IIS サポートを使用するとき、アプリの起動問題を解決する場合にのみ推奨されます。ローカル デバッグ時、IIS Express でアプリを実行している場合は推奨されません。
一般的なアプリ ログの目的には、stdout ログを使わないでください。 ASP.NET Core アプリでのルーチン ログの場合は、ログ ファイルのサイズを制限し、ログをローテーションするログ ライブラリを使います。 詳しくは、「サードパーティ製のログ プロバイダー」をご覧ください。
ログ ファイルの作成時には、タイムスタンプとファイルの拡張子が自動的に追加されます。 ログ ファイル名は、タイムスタンプ、プロセス ID、およびファイル拡張子 ( .log) を stdoutLogFile
パスの最後のセグメント (通常は stdout) にアンダースコアで区切って追加することで構成されます。 stdoutLogFile
パスが stdout で終わっている場合、PID が 1934 で 2018 年 2 月 5 日の 19:42:32 に作成されたアプリのログのファイル名は、stdout_20180205194132_1934.log になります。
次のサンプルでは、aspNetCore
要素により相対パス .\log\
で stdout ログ記録が構成されます。 AppPool のユーザー identity に、指定されたパスへの書き込みアクセス許可があることを確認してください。
<aspNetCore processPath="dotnet"
arguments=".\MyApp.dll"
stdoutLogEnabled="true"
stdoutLogFile=".\logs\stdout">
</aspNetCore>
Azure App Service デプロイのためにアプリを公開するとき、Web SDK により stdoutLogFile
値が \\?\%home%\LogFiles\stdout
に設定されます。 Azure App Service でホストされるアプリの場合、%home
環境変数が事前定義されます。
ログ記録のフィルター ルールを作成するには、ASP.NET Core ログ記録のドキュメントの「コードでログ フィルター ルールを適用する」セクションを参照してください。
パス形式の詳細については、「Windows システムのファイル パス形式」を参照してください。
プロキシの構成で HTTP プロトコルとペアリング トークンを使用する
ASP.NET Core モジュールと Kestrel の間に作成されるプロキシは、HTTP プロトコルを使います。 モジュールと Kestrel の間のトラフィックが、サーバーから離れた場所で傍受される危険はありません。
ペアリング トークンを使用すると、Kestrel によって受信される要求が IIS によってプロキシされたものであり、他のソースからのものでないことを保証できます。 ペアリング トークンは、モジュールによって作成されて、環境変数 (ASPNETCORE_TOKEN
) に設定されます。 ペアリング トークンはまた、プロキシされたすべての要求のヘッダー (MS-ASPNETCORE-TOKEN
) にも設定されます。 IIS ミドルウェアは、受信した各要求をチェックし、ペアリング トークン ヘッダーの値が環境変数の値と一致することを確認します。 トークンの値が一致しない場合、要求はログに記録され、拒否されます。 ペアリング トークン環境変数およびモジュールと Kestrel の間のトラフィックには、サーバーから離れた場所からアクセスすることはできません。 ペアリング トークンの値がわからなければ、攻撃者は IIS ミドルウェアのチェックをバイパスする要求を送信できません。
IIS 共有構成での ASP.NET Core モジュール
ASP.NET Core モジュールのインストーラーは、TrustedInstaller アカウントのアクセス許可を使って実行します。 ローカル システム アカウントには、IIS 共有構成によって使われる共有パスに対する変更アクセス許可がないため、インストーラーが共有上の applicationHost.config ファイル内のモジュール設定を構成しようとすると、アクセス拒否エラーがスローされます。
IIS 共有構成を使うときは、次の手順で行います。
- IIS 共有構成を無効にします。
- インストーラーを実行します。
- 更新された applicationHost.config ファイルを共有にエクスポートします。
- IIS 共有構成を再び有効にします。
モジュールのバージョンとホスティング バンドル インストーラーのログ
インストールされている ASP.NET Core モジュールのバージョンを確認するには:
- ホスティング システム上で、 %windir%\System32\inetsrv に移動します。
- aspnetcore.dll ファイルを探します。
- ファイルを右クリックし、コンテキスト メニューの [プロパティ] を選びます。
- [詳細] タブを選びます。 [ファイル バージョン] と [製品バージョン] が、インストールされているモジュールのバージョンを表します。
モジュールのホスティング バンドル インストーラーのログは C:\Users\%UserName%\AppData\Local\Temp にあります。ファイル名は dd_DotNetCoreWinSvrHosting__<timestamp>_000_AspNetCoreModule_x64.log です。
モジュール、スキーマ、構成ファイルの場所
Module
IIS (x86/amd64):
%windir%\System32\inetsrv\aspnetcore.dll
%windir%\SysWOW64\inetsrv\aspnetcore.dll
IIS Express (x86/amd64):
%ProgramFiles%\IIS Express\aspnetcore.dll
%ProgramFiles(x86)%\IIS Express\aspnetcore.dll
Schema
IIS
- %windir%\System32\inetsrv\config\schema\aspnetcore_schema.xml
IIS Express
- %ProgramFiles%\IIS Express\config\schema\aspnetcore_schema.xml
構成
IIS
- %windir%\System32\inetsrv\config\applicationHost.config
IIS Express
Visual Studio: {アプリケーションのルート}\.vs\config\applicationHost.config
iisexpress.exe CLI: %USERPROFILE%\Documents\IISExpress\config\applicationhost.config
ファイルは、applicationHost.config ファイルで aspnetcore を検索することにより見つかります。
その他の技術情報
- IIS を使用した Windows での ASP.NET Core のホスト
- Azure App Service に ASP.NET Core アプリを展開する
- ASP.NET Core モジュール参照ソース [既定のブランチ (main)]: [ブランチ] ドロップ ダウン リストを使用して、特定のリリース (
release/3.1
など) を選択する。 - ASP.NET Core での IIS モジュール
ASP.NET Core