ApplicationInsights.config または .xml を使って Application Insights SDK を構成する
Application Insights .NET SDK は多くの NuGet パッケージで構成されています。 コア パッケージ は、テレメトリを Application Insights に送信するための API を提供します。 追加パッケージは、アプリケーションとそのコンテキストからテレメトリを自動的に追跡するためのテレメトリ モジュールと初期化子を提供します。 構成ファイルを調整することによって、テレメトリ モジュールと初期化子を有効または無効にできます。 その中のいくつかに対し、パラメーターを設定することもできます。
注意事項
Azure Monitor Application Insights を利用する新規のアプリケーションやお客様には、Azure Monitor OpenTelemetry Distro をお勧めします。 Azure Monitor OpenTelemetry Distro では、Application Insights SDK と同様の機能とエクスペリエンスが提供されます。 .NET、Node.js、Python 用の移行ガイドを使用して Application Insights SDK から移行することはできますが、下位互換性を確保するためのいくつかの機能の追加の取り組みが行われている最中です。
構成ファイルの名前は ApplicationInsights.config
または ApplicationInsights.xml
です。 名前はアプリケーションの種類によって異なります。 構成ファイルは、SDK のほとんどのバージョンのインストール時に、プロジェクトに自動的に追加されます。 既定では、[追加]>[Application Insights Telemetry] がサポートされている Visual Studio テンプレート プロジェクトからの自動化されたエクスペリエンスを使用すると、ApplicationInsights.config
ファイルがプロジェクトのルート フォルダーに作成されます。 コンパイルされると、bin フォルダーにコピーされます。 また、IIS サーバー上の Application Insights エージェントによって Web アプリにも追加されます。 Azure Web サイトの拡張機能または Azure VM の拡張機能と仮想マシン スケールセットが使用されている場合、構成ファイルは無視されます。
Web ページの SDK を制御するための同等のファイルはありません。
この記事では、構成ファイルの各セクション、SDK のコンポーネントの制御方法、それらのコンポーネントを読み込む NuGet パッケージについて説明します。
Note
ApplicationInsights.config
および .xml の手順は、.NET Core SDK には適用されません。 .NET Core アプリケーションを構成するには、「Application Insights for ASP.NET Core アプリケーション」の指示に従ってください。
テレメトリ モジュール (ASP.NET)
各テレメトリ モジュールは特定の種類のデータを回収し、コア API を利用してデータを送信します。 モジュールはさまざまな NuGet パッケージによりインストールされます。NuGet パッケージはまた、必要な行を .config ファイルに追加します。
各モジュールの構成ファイルにノードが存在します。 モジュールを無効にするには、ノードを削除するか、コメント アウトします。
依存関係の追跡
依存関係の追跡 により、アプリがデータベースと外部サービスに行った呼び出しに関するテレメトリが回収されます。 このモジュールを IIS サーバーで機能させるには、Application Insights エージェントをインストールする必要があります。
TrackDependency API を使用して、独自の依存関係追跡コードを記述することもできます。
Microsoft.ApplicationInsights.DependencyCollector.DependencyTrackingTelemetryModule
- Microsoft.ApplicationInsights.DependencyCollector NuGet パッケージ
エージェントベース (コードなし) アタッチを使用してコードを変更することなく、依存関係を自動収集できます。 これを Azure Web アプリで使用するには、Application Insights 拡張機能を有効にします。 Azure VM または Azure 仮想マシン スケール セットで使用するには、VM と仮想マシン スケール セットのアプリケーション監視拡張を有効にします。
パフォーマンス コレクター
パフォーマンス コレクターでは、CPU、メモリ、IIS インストールのネットワーク負荷など、システム パフォーマンス カウンターを収集します。 自分で設定したパフォーマンス カウンターなど、回収するカウンターを指定できます。
Microsoft.ApplicationInsights.Extensibility.PerfCounterCollector.PerformanceCollectorModule
- Microsoft.ApplicationInsights.PerfCounterCollector NuGet パッケージ
Application Insights 診断テレメトリ
DiagnosticsTelemetryModule
クラスでは Application Insights インストルメンテーション コード自体のエラーを報告します。 たとえば、コードがパフォーマンス カウンターにアクセスできない場合や、ITelemetryInitializer
が例外をスローする場合などです。 診断検索に、このモジュールが追跡するトレース テレメトリが表示されます。
Microsoft.ApplicationInsights.Extensibility.Implementation.Tracing.DiagnosticsTelemetryModule
- Microsoft.ApplicationInsights NuGet パッケージ このパッケージのみをインストールする場合、ApplicationInsights.config ファイルは自動作成されません。
開発者モード
DeveloperModeWithDebuggerAttachedTelemetryModule
クラスでは、デバッガーがアプリケーション プロセスに接続されているときに、Application Insights の TelemetryChannel
にデータを即座に、一度に 1 つのテレメトリ項目を送信するよう強制します。 この設計により、アプリケーションがテレメトリを追跡してから、それが Application Insights ポータルに表示されるまでの時間が縮小されます。 ここでは、CPU とネットワーク帯域幅のオーバーヘッドが著しく費やされます。
Microsoft.ApplicationInsights.WindowsServer.DeveloperModeWithDebuggerAttachedTelemetryModule
- Application Insights Windows Server NuGet パッケージ
Web 要求の追跡
Web 要求の追跡では、HTTP 要求の応答時間と結果コードを報告します。
Microsoft.ApplicationInsights.Web.RequestTrackingTelemetryModule
- Microsoft.ApplicationInsights.Web NuGet パッケージ
例外の追跡
ExceptionTrackingTelemetryModule
クラスは Web アプリで処理されない例外を追跡します。 詳細については、「失敗と例外」を参照してください。
Microsoft.ApplicationInsights.Web.ExceptionTrackingTelemetryModule
.- Microsoft.ApplicationInsights.Web NuGet パッケージ。
Microsoft.ApplicationInsights.WindowsServer.UnobservedExceptionTelemetryModule
: 監視されていないタスクを追跡します。 例外。Microsoft.ApplicationInsights.WindowsServer.UnhandledExceptionTelemetryModule
: worker ロール、Windows サービス、コンソール アプリケーションのハンドルされない例外を追跡します。- Application Insights Windows Server NuGet パッケージ
EventSource の追跡
EventSourceTelemetryModule
クラスを使用すると、Application Insights にトレースとして送信される EventSource イベントを構成できます。 EventSource イベントの追跡については、「EventSource イベントを使用する」をご覧ください。
Microsoft.ApplicationInsights.EventSourceListener.EventSourceTelemetryModule
- Microsoft.ApplicationInsights.EventSourceListener
ETW イベントの追跡
EtwCollectorTelemetryModule
クラスを使用すると、Application Insights にトレースとして送信される ETW プロバイダーを構成できます。 ETW イベントの追跡については、「ETW イベントを使用する」をご覧ください。
Microsoft.ApplicationInsights.EtwCollector.EtwCollectorTelemetryModule
- Microsoft.ApplicationInsights.EtwCollector
Microsoft.ApplicationInsights
Microsoft.ApplicationInsights
パッケージには、SDK のコア API が用意されています。 他のテレメトリ モジュールでは、この API を使用します。 独自のテレメトリを定義するために使用することもできます。
- ApplicationInsights.config にエントリがありません。
- Microsoft.ApplicationInsights NuGet パッケージ この NuGet だけをインストールする場合、.config ファイルは生成されません。
テレメトリ チャネル
テレメトリ チャネルでは、テレメトリのバッファリングと Application Insights サービスへの送信が管理されます。
Microsoft.ApplicationInsights.WindowsServer.TelemetryChannel.ServerTelemetryChannel
は Web アプリケーション用の既定のチャネルです。 メモリ内にデータをバッファーし、より信頼性の高いテレメトリ配信のために、再試行のメカニズムとローカル ディスク ストレージを採用しています。Microsoft.ApplicationInsights.InMemoryChannel
は軽量なテレメトリ チャネルです。 他のチャネルが構成されていない場合に使用されます。
テレメトリの初期化子 (ASP.NET)
テレメトリの初期化子は、テレメトリのあらゆるアイテムと共に送信されるコンテキスト プロパティを設定します。
独自の初期化子を記述し 、コンテキスト プロパティを設定できます。
標準の初期化子は Web または WindowsServer NuGet パッケージによりすべて設定されます。
AccountIdTelemetryInitializer
はAccountId
プロパティを設定します。AuthenticatedUserIdTelemetryInitializer
は JavaScript SDK による設定に基づきAuthenticatedUserId
プロパティを設定します。AzureRoleEnvironmentTelemetryInitializer
は、Azure ランタイム環境から抽出された情報により、すべてのテレメトリ項目のDevice
コンテキストのRoleName
およびRoleInstance
プロパティを更新します。BuildInfoConfigComponentVersionTelemetryInitializer
は、MS ビルドによって生成されたBuildInfo.config
ファイルから抽出された値を使用して、すべてのテレメトリ項目のComponent
コンテキストのVersion
プロパティを更新します。ClientIpHeaderTelemetryInitializer
は、要求のX-Forwarded-For
HTTP ヘッダーに基づいて、すべてのテレメトリ項目のLocation
コンテキストのIp
プロパティを更新します。DeviceTelemetryInitializer
は、すべてのテレメトリ項目のDevice
コンテキストの次のプロパティを更新します。Type
はPC
に設定されます。Id
は Web アプリケーションが実行中のコンピューターのドメイン名に設定します。OemName
は WMI を使用してWin32_ComputerSystem.Manufacturer
フィールドから抽出された値に設定します。Model
は WMI を使用してWin32_ComputerSystem.Model
フィールドから抽出された値に設定します。NetworkType
はNetworkInterface
プロパティから抽出された値に設定します。Language
はCurrentCulture
プロパティの名前に設定します。
DomainNameRoleInstanceTelemetryInitializer
は、Web アプリケーションを実行中のコンピューターのドメイン名を使用して、すべてのテレメトリ項目のDevice
コンテキストのRoleInstance
プロパティを更新します。OperationNameTelemetryInitializer
は、HTTP メソッド、ASP.NET MVC コントローラーの名前、要求の処理のために呼び出されるアクションに基づいて、すべてのテレメトリ項目のRequestTelemetry
のName
プロパティとOperation
コンテキストのName
プロパティを更新します。OperationIdTelemetryInitializer
またはOperationCorrelationTelemetryInitializer
は、追跡されたすべてのテレメトリ項目のOperation.Id
コンテキスト プロパティを更新し、自動生成されたRequestTelemetry.Id
が付いた要求を処理します。SessionTelemetryInitializer
は、ユーザーのブラウザーで実行するApplicationInsights
JavaScript インストルメンテーション コードが生成するai_session
Cookie から抽出された値を使用して、すべてのテレメトリ項目のSession
コンテキストのId
プロパティを更新します。SyntheticTelemetryInitializer
またはSyntheticUserAgentTelemetryInitializer
は、可用性テストや検索エンジン ボットなど、合成ソースからの要求の処理時に追跡されるすべてのテレメトリ項目のUser
、Session
、Operation
のコンテキスト プロパティを更新します。 既定では、メトリックス エクスプローラーには合成テレメトリは表示されません。<Filters>
は、要求の識別プロパティを設定します。UserTelemetryInitializer
は、ユーザーのブラウザーで実行する Application Insights JavaScript インストルメンテーション コードが生成するai_user
Cookie から抽出された値を使用して、すべてのテレメトリ項目のUser
コンテキストのId
およびAcquisitionDate
のプロパティを更新します。WebTestTelemetryInitializer
は、可用性テストからの HTTP 要求に対してユーザー ID、セッション ID、および合成ソース プロパティを設定します。<Filters>
は、要求の識別プロパティを設定します。
Azure Service Fabric で実行されている .NET アプリケーションの場合、Microsoft.ApplicationInsights.ServiceFabric
NuGet パッケージを含めることができます。 このパッケージには、Service Fabric のプロパティをテレメトリ項目に追加する FabricTelemetryInitializer
プロパティが含まれています。 詳細については、この NuGet パッケージによって追加されるプロパティに関する GitHub のページをご覧ください。
テレメトリ プロセッサ (ASP.NET)
テレメトリ プロセッサは、SDK からポータルに送信される前に、各テレメトリ項目をフィルター処理して変更できます。
独自のテレメトリ プロセッサを記述できます。
アダプティブ サンプリング テレメトリ プロセッサー (2.0.0-beta3 以降)
この機能は既定で有効化されています。 アプリが多数のテレメトリを送信する場合、このプロセッサはその一部を削除します。
<TelemetryProcessors>
<Add Type="Microsoft.ApplicationInsights.WindowsServer.TelemetryChannel.AdaptiveSamplingTelemetryProcessor, Microsoft.AI.ServerTelemetryChannel">
<MaxTelemetryItemsPerSecond>5</MaxTelemetryItemsPerSecond>
</Add>
</TelemetryProcessors>
パラメーターは、アルゴリズムが実現しようとするターゲットを指定します。 SDK の各インスタンスは独立して動作します。 サーバーが複数のコンピューターのクラスターである場合、テレメトリの実際の量もそれに応じて増加します。
詳細については、サンプリングに関する記事を参照してください。
固定レート サンプリング テレメトリ プロセッサー (2.0.0-beta1 以降)
標準的なサンプリング テレメトリ プロセッサも用意されています (2.0.1 以降)。
<TelemetryProcessors>
<Add Type="Microsoft.ApplicationInsights.WindowsServer.TelemetryChannel.SamplingTelemetryProcessor, Microsoft.AI.ServerTelemetryChannel">
<!-- Set a percentage close to 100/N where N is an integer. -->
<!-- E.g. 50 (=100/2), 33.33 (=100/3), 25 (=100/4), 20, 1 (=100/100), 0.1 (=100/1000) -->
<SamplingPercentage>10</SamplingPercentage>
</Add>
</TelemetryProcessors>
ConnectionString
Note
インストルメンテーション キーのインジェストのサポートは、2025 年 3 月 31 日に終了します。 インストルメンテーション キーのインジェストは引き続き機能しますが、この機能の更新プログラムやサポートは提供されなくなります。 接続文字列に移行することで、新機能をご利用いただけます。
この設定により、データが表示される Application Insights リソースが決定されます。 通常は、アプリケーションごとに、個別の接続文字列を使用して個別のリソースを作成します。
コード サンプルについては、「Application Insights の接続文字列」を参照してください。
接続文字列を動的に設定する場合 (たとえば、アプリケーションからの結果を別のリソースに送信するために)、構成ファイルから接続文字列を省略し、代わりにコードで設定することができます。
標準テレメトリ モジュールを含む、TelemetryClient
のすべてのインスタンスの接続文字列を設定するには、ASP.NET サービスの global.aspx.cs などの初期化メソッドで次の手順を行います。
using Microsoft.ApplicationInsights.Extensibility;
using Microsoft.ApplicationInsights;
protected void Application_Start()
{
TelemetryConfiguration configuration = TelemetryConfiguration.CreateDefault();
configuration.ConnectionString = "InstrumentationKey=00000000-0000-0000-0000-000000000000";
var telemetryClient = new TelemetryClient(configuration);
特定のイベント セットを異なるリソースに送信する場合、特定のテレメトリ クライアントのキーを設定できます。
var tc = new TelemetryClient();
tc.Context.ConnectionString = "InstrumentationKey=00000000-0000-0000-0000-000000000000";
tc.TrackEvent("myEvent");
// ...
新しいキーを取得するには、Application Insights ポータルで新しいリソースを作成します。
ApplicationId プロバイダー
このプロバイダーは v2.6.0 以降で使用できます。
このプロバイダーの目的は、接続文字列に基づいて、アプリケーション ID を検索することです。 アプリケーション ID は RequestTelemetry
と DependencyTelemetry
に含まれており、ポータルでの相関関係を決定するために使用されます。
この機能は、TelemetryConfiguration.ApplicationIdProvider
をコード内または構成ファイル内に設定することで有効化されます。
インターフェイス:IApplicationIdProvider
public interface IApplicationIdProvider
{
bool TryGetApplicationId(string instrumentationKey, out string applicationId);
}
Microsoft.ApplicationInsights SDK 内に次の 2 つの実装が用意されています。ApplicationInsightsApplicationIdProvider
と DictionaryApplicationIdProvider
。
ApplicationInsightsApplicationIdProvider
このラッパーはプロファイル API 用です。 要求を調整し、結果をキャッシュします。
このプロバイダーは、Microsoft.ApplicationInsights.DependencyCollector または Microsoft.ApplicationInsights.Web のいずれかをインストールしたときに、構成ファイルに追加されます。
このクラスには、省略可能なプロパティ ProfileQueryEndpoint
があります。 既定では、https://dc.services.visualstudio.com/api/profiles/{0}/appId
に設定されています。 この構成のプロキシを構成する必要がある場合は、ベース アドレスのプロキシ化と "/api/profiles/{0}/appId"
を含めることをお勧めします。 {0}
は実行時に要求ごとにインストルメンテーション キーに置き換わることに注意してください。
ApplicationInsights.config による構成の例
<ApplicationInsights>
...
<ApplicationIdProvider Type="Microsoft.ApplicationInsights.Extensibility.Implementation.ApplicationId.ApplicationInsightsApplicationIdProvider, Microsoft.ApplicationInsights">
<ProfileQueryEndpoint>https://dc.services.visualstudio.com/api/profiles/{0}/appId</ProfileQueryEndpoint>
</ApplicationIdProvider>
...
</ApplicationInsights>
コードによる構成の例
TelemetryConfiguration.Active.ApplicationIdProvider = new ApplicationInsightsApplicationIdProvider();
DictionaryApplicationIdProvider
この静的プロバイダーは、構成済みのインストルメンテーション キーとアプリケーション ID のペアに依存しています。
このクラスには Defined
プロパティがあります。これは、インストルメンテーション キーとアプリケーション ID のペアである Dictionary<string,string>
です。
このクラスには、オプションのプロパティ Next
があり、構成にない接続文字列が要求されたときに使用する、別のプロバイダーの構成に使うことができます。
ApplicationInsights.config による構成の例
<ApplicationInsights>
...
<ApplicationIdProvider Type="Microsoft.ApplicationInsights.Extensibility.Implementation.ApplicationId.DictionaryApplicationIdProvider, Microsoft.ApplicationInsights">
<Defined>
<Type key="InstrumentationKey_1" value="ApplicationId_1"/>
<Type key="InstrumentationKey_2" value="ApplicationId_2"/>
</Defined>
<Next Type="Microsoft.ApplicationInsights.Extensibility.Implementation.ApplicationId.ApplicationInsightsApplicationIdProvider, Microsoft.ApplicationInsights" />
</ApplicationIdProvider>
...
</ApplicationInsights>
コードによる構成の例
TelemetryConfiguration.Active.ApplicationIdProvider = new DictionaryApplicationIdProvider{
Defined = new Dictionary<string, string>
{
{"InstrumentationKey_1", "ApplicationId_1"},
{"InstrumentationKey_2", "ApplicationId_2"}
}
};
ASP.NET アプリケーションのスナップショット コレクションの構成
ASP.NET アプリケーションのスナップショット コレクションの構成
次のステップ
API の詳細については、こちらをご覧ください。