カスタムのイベントとメトリックのための Application Insights API

アプリケーションに数行のコードを挿入して、ユーザーの行動を調べたり、問題の診断に役立つ情報を取得したりすることができます。 デバイスとデスクトップ アプリケーション、Web クライアント、Web サーバーからテレメトリを送信できます。 Application Insights コア テレメトリ API を使用すると、カスタムのイベントやメトリック、独自バージョンの標準テレメトリを送信できます。 この API は、Application Insights の標準のデータ コレクターで使用される API と同じものです。

Note

インストルメンテーション キーのインジェストのサポートは、2025 年 3 月 31 日に終了します。 インストルメンテーション キーのインジェストは引き続き機能しますが、この機能の更新プログラムやサポートは提供されなくなります。 接続文字列に移行することで、新機能をご利用いただけます。

API の概要

コア API は、GetMetric (.NET のみ) のような少しの違いは別として、すべてのプラットフォームにわたって同一です。

Method 使用目的
TrackPageView ページ、画面、ペイン、またはフォーム。
TrackEvent ユーザー アクションとその他のイベント。 ユーザーの行動を追跡するために、またはパフォーマンスを監視するために使用されます。
GetMetric 0 と多次元メトリックは、C# の場合のみ、一元的に構成された集計です。
TrackMetric キューの長さなど、特定のイベントに関連しないパフォーマンスを測定します。
TrackException 診断用に例外を記録します。 他のイベントとの関連で例外の発生箇所を追跡し、スタック トレースを調べます。
TrackRequest パフォーマンス分析用にサーバー要求の頻度と期間を記録します。
TrackTrace リソース診断ログ メッセージ。 サードパーティのログをキャプチャすることもできます。
TrackDependency アプリが依存する外部コンポーネントへの呼び出しの実行時間と頻度を記録します。

これらのテレメトリの呼び出しのほとんどに プロパティとメトリックをアタッチ できます。

開始する前に

Application Insights SDK の参照がまだない場合:

TelemetryClient インスタンスの取得

TelemetryClient インスタンスを取得します (Web ページの JavaScript を除く)。

ASP.NET Core アプリと .NET/.NET Core 向けの非 HTTP/ワーカー アプリの場合、それぞれのドキュメントに説明されているとおり、依存関係インジェクション コンテナーから TelemetryClient のインスタンスを取得します。

Azure Functions v2 以降または Azure WebJobs v3 以降を使用する場合は、「Azure Functions を監視する」を参照してください。

C#

private TelemetryClient telemetry = new TelemetryClient();

このメソッドが廃止されたことを示すメッセージが表示される場合は、microsoft/ApplicationInsights-dotnet#1152 を参照してください。

Visual Basic

Private Dim telemetry As New TelemetryClient

Java

private TelemetryClient telemetry = new TelemetryClient();

Node.js

var telemetry = applicationInsights.defaultClient;

TelemetryClient はスレッド セーフです。

ASP.NET および Java プロジェクトの場合は、受信 HTTP 要求が自動的にキャプチャされます。 アプリの他のモジュール用に TelemetryClient のインスタンスをさらに作成することをお勧めします。 たとえば、ミドルウェア クラスでビジネス ロジック イベントを報告する 1 つの TelemetryClient インスタンスを使用できます。 マシンを識別するために UserIdDeviceId などのプロパティを設定できます。 こうした情報は、インスタンスから送信されるすべてのイベントに付属します。

C#

TelemetryClient.Context.User.Id = "...";
TelemetryClient.Context.Device.Id = "...";

Java

telemetry.getContext().getUser().setId("...");
telemetry.getContext().getDevice().setId("...");

Node.js プロジェクトでは、新しいインスタンスを作成するために new applicationInsights.TelemetryClient(instrumentationKey?) を使用できます。 この方法は、シングルトン defaultClient から分離された構成を必要とするシナリオにのみお勧めします。

TrackEvent

Application Insights の "カスタム イベント" はデータ ポイントであり、メトリックス エクスプローラーでは集計カウントとして、診断検索では個々の発生として表示できます。 (これは MVC にも他のフレームワークの "イベント" にも関連していません)。

さまざまなイベントをカウントするために、TrackEvent 呼び出しを挿入します。 たとえば、ユーザーが特定の機能を選択する頻度を追跡できます。 または、特定の目標を達成する頻度や、特定の種類の間違いを行う頻度を把握することもできます。

たとえば、ゲーム アプリで、ユーザーが勝利したときにイベントを送信します。

JavaScript

appInsights.trackEvent({name:"WinGame"});

C#

telemetry.TrackEvent("WinGame");

Visual Basic

telemetry.TrackEvent("WinGame")

Java

telemetry.trackEvent("WinGame");

Node.js

telemetry.trackEvent({name: "WinGame"});

Log Analytics でのカスタム イベント

テレメトリは、Application Insights ログのタブまたは使用エクスペリエンスcustomEvents テーブルにあります。 イベントは、trackEvent(..) またはクリック分析自動収集プラグインから取得できます。

サンプリングが実行中の場合は、itemCount プロパティは 1 より大きい値を示します。 たとえば itemCount==10trackEvent() への 10 回の呼び出しで、サンプリング プロセスはそれらのうちの 1 つだけを転送したことを意味します。 カスタム イベントの正しい数を取得するには、customEvents | summarize sum(itemCount) などのコードを使用します。

注意

itemCount の最小値は 1 です。レコード自体はエントリを表します。

GetMetric

GetMetric() 呼び出しを効果的に使用し、.NET および .NET Core アプリケーション用にローカルで事前集計されたメトリックをキャプチャする方法については、「.NET および .NET Core でのカスタム メトリックの収集」を参照してください。

TrackMetric

Note

Microsoft.ApplicationInsights.TelemetryClient.TrackMetric は、メトリックを送信するための推奨メソッドではありません。 メトリックは送信される前に必ず、ある期間にわたって事前に集計される必要があります。 GetMetric(..) オーバーロードのいずれかを使用して、SDK の事前集計機能にアクセスするためのメトリック オブジェクトを取得します。

独自の事前集計ロジックを実装する場合は、TrackMetric() メソッドを使用して集計結果を送信できます。 アプリケーションで、一定時間にわたる集計を行わず、すべての機会に個別のテレメトリ項目を送信する必要がある場合は、おそらくイベント テレメトリのユース ケースに該当します。 以下を参照してください。TelemetryClient.TrackEvent (Microsoft.ApplicationInsights.DataContracts.EventTelemetry)

Application Insights では、特定のイベントにアタッチされていないメトリックをグラフ化できます。 たとえば、一定の間隔でキューの長さを監視できます。 メトリックでは、個々の測定値は変化と傾向よりも関心が薄いため、統計グラフが役に立ちます。

Application Insights にメトリックを送信するには、TrackMetric(..) API を使用します。 メトリックを送信するには、次の 2 つの方法があります。

  • 単一値。 アプリケーションで、測定を実行するたびに、対応する値を Application Insights に送信します。

    たとえば、コンテナー内の項目数を記述するメトリックがあるとします。 特定の期間に、まずコンテナーに 3 つの項目を配置し、次に 2 つの項目を削除します。 それに応じて、TrackMetric を 2 回呼び出します。 まず、値 3 を渡してから値 -2 を渡します。 Application Insights は、両方の値を格納します。

  • 集計。 メトリックを使用する場合、個々の測定値はあまり重要ではありません。 代わりに、特定の期間に発生したことの概要が重要です。 このような概要は 集計 と呼ばれます。

    前述の例では、その期間の集計メトリックの合計は 1 で、メトリック値のカウントは 2 となります。 集計アプローチを使用する場合、期間ごとに TrackMetric を 1 回だけ呼び出し、集計値を送信します。 すべての関連情報を収集しながら、Application Insights に送信するデータ ポイントを少なくすることによって、コストとパフォーマンスのオーバーヘッドを大幅に削減できるため、この方法をお勧めします。

単一値の例

1 つのメトリック値を送信するには:

JavaScript

appInsights.trackMetric({name: "queueLength", average: 42});

C#

var sample = new MetricTelemetry();
sample.Name = "queueLength";
sample.Sum = 42.3;
telemetryClient.TrackMetric(sample);

Java

telemetry.trackMetric("queueLength", 42.0);

Node.js

telemetry.trackMetric({name: "queueLength", value: 42.0});

Log Analytics のカスタム メトリック

テレメトリは、Application Insights AnalyticscustomMetrics テーブルにあります。 各行は、アプリでの trackMetric(..) に対する呼び出しを表します。

  • valueSum: これは測定値の合計です。 平均値を取得するには、valueCount で除算します。
  • valueCount: この trackMetric(..) 呼び出しで集計された測定値の数。

注意

valueCount の最小値は 1 です。レコード自体はエントリを表します。

ページ ビュー

デバイスまたは Web ページ アプリケーションでは、各画面または各ページが読み込まれた場合既定でページ ビュー テレメトリが送信されます。 ただし、規定を変更して、ページ ビューを追跡する回数を増やしたり、変えたりできます。 たとえば、タブまたはペインを表示するアプリでは、ユーザーが新しいペインを開くたびにページを追跡することもできます。

ユーザーとセッションのデータはページ ビューとともにプロパティとして送信されます。そのため、ページ ビューのテレメトリがあれば、ユーザーとセッションのグラフがアクティブになります。

カスタム ページ ビュー

JavaScript

appInsights.trackPageView("tab1");

C#

telemetry.TrackPageView("GameReviewPage");

Visual Basic

telemetry.TrackPageView("GameReviewPage")

Java

telemetry.trackPageView("GameReviewPage");

別々の HTML ページ内で複数のタブを使用している場合、URL を指定することもできます。

appInsights.trackPageView("tab1", "http://fabrikam.com/page1.htm");

ページ ビューのタイミング

既定では、ページ ビューの読み込み時間として報告される時間は、ブラウザーが要求を送信した時点からブラウザーのページ読み込みイベントが呼び出されるまでが測定されます。

代わりに、次のいずれかを行うことができます。

  • trackPageView の呼び出し appInsights.trackPageView("tab1", null, null, null, durationInMilliseconds); で明示的な時間を設定する。
  • ページ ビューのタイミングの呼び出し (startTrackPagestopTrackPage) を使用する。

JavaScript

// To start timing a page:
appInsights.startTrackPage("Page1");

...

// To stop timing and log the page:
appInsights.stopTrackPage("Page1", url, properties, measurements);

1 番目のパラメーターとして使用する名前により、開始呼び出しと停止呼び出しを関連付けます。 既定値は現在のページ名です。

メトリックス エクスプローラーに結果として表示されるページ読み込み時間は、開始呼び出しと停止呼び出しの時間間隔から求められます。 実際の時間間隔はユーザーが決定します。

Log Analytics でのページ テレメトリ

Log Analytics では、次の 2 つのテーブルに、ブラウザー操作からのデータが表示されます。

  • pageViews: URL とページ タイトルに関するデータが含まれます。
  • browserTimings: 受信データの処理にかかった時間などのクライアントのパフォーマンスに関するデータが含まれます。

ブラウザーでさまざまなページの処理にかかる時間を知るには、次のようにします。

browserTimings
| summarize avg(networkDuration), avg(processingDuration), avg(totalDuration) by name

さまざまなブラウザーの使用頻度を検出するには、次のようにします。

pageViews
| summarize count() by client_Browser

AJAX 呼び出しにページ ビューを関連付けるには、依存関係によって結合します。

pageViews
| join (dependencies) on operation_Id

TrackRequest

HTTP 要求を記録するために、サーバー SDK によって TrackRequest が使用されます。

Web サービス モジュールが実行されていない状況で要求をシミュレーションする場合に、これを自分で呼び出すこともできます。

要求テレメトリを送信するための推奨される方法は、要求が操作コンテキストとして機能しているところです。

操作コンテキスト

テレメトリ項目を操作コンテキストと関連付けることで、それらの項目を互いに相関させることができます。 標準の要求追跡モジュールでは、HTTP 要求の処理中に送信される例外や他のイベントに対してこの関連付けが行われます。 検索分析では、操作 ID を使用して、要求に関連付けられたイベントを簡単に見つけることができます。

相関関係の詳細については、「Application Insights におけるテレメトリの相関付け」を参照してください。

手動でテレメトリを追跡する場合、テレメトリの相関付けを確実に行うための最も簡単な方法として、次のパターンを使用できます。

C#

// Establish an operation context and associated telemetry item:
using (var operation = telemetryClient.StartOperation<RequestTelemetry>("operationName"))
{
    // Telemetry sent in here will use the same operation ID.
    ...
    telemetryClient.TrackTrace(...); // or other Track* calls
    ...

    // Set properties of containing telemetry item--for example:
    operation.Telemetry.ResponseCode = "200";

    // Optional: explicitly send telemetry item:
    telemetryClient.StopOperation(operation);

} // When operation is disposed, telemetry item is sent.

操作コンテキストの設定に合わせて、指定した種類のテレメトリ項目を StartOperation で作成します。 テレメトリ項目は、操作を破棄するか StopOperation を明示的に呼び出すと送信されます。 テレメトリの種類として RequestTelemetry を使用する場合、その継続時間は開始から停止までの間の一定の間隔に設定されます。

操作のスコープ内にあるテレメトリ項目は、その操作の子になります。 操作コンテキストは入れ子にできます。

検索では、操作コンテキストを使用して関連項目の一覧が作成されます。

関連項目の一覧を示すスクリーンショット。

カスタム操作の追跡の詳細については、「Application Insights .NET SDK でカスタム操作を追跡する」を参照してください。

Log Analytics での要求

Application Insights Analytics で、要求は requests テーブルに表示されます。

サンプリングが実行中の場合は、itemCount プロパティは 1 より大きい値を示します。 たとえば itemCount==10trackRequest() への 10 回の呼び出しで、サンプリング プロセスはそれらのうちの 1 つだけを転送したことを意味します。 要求の正しい数と要求名別にセグメント化された平均所要時間を取得するには、次のようなコードを使用します。

requests
| summarize count = sum(itemCount), avgduration = avg(duration) by name

TrackException

次の目的で例外を Application Insights に送信します。

レポートにはスタック トレースが含まれます。

C#

try
{
    ...
}
catch (Exception ex)
{
    telemetry.TrackException(ex);
}

Java

try {
    ...
} catch (Exception ex) {
    telemetry.trackException(ex);
}

JavaScript

try
{
    ...
}
catch (ex)
{
    appInsights.trackException({exception: ex});
}

Node.js

try
{
    ...
}
catch (ex)
{
    telemetry.trackException({exception: ex});
}

SDK が多数の例外を自動的にキャッチするため、常に TrackException を明示的に呼び出す必要はありません。

({
    instrumentationKey: "your key",
    disableExceptionTracking: true
})

Log Analytics での例外

Application Insights Analytics で、例外は exceptions テーブルに表示されます。

サンプリングが実行中の場合は、itemCount プロパティは 1 より大きい値を示します。 たとえば itemCount==10trackException() への 10 回の呼び出しで、サンプリング プロセスはそれらのうちの 1 つだけを転送したことを意味します。 例外の種類別にセグメント化された例外の正しい数を取得するには、次のようなコードを使用します。

exceptions
| summarize sum(itemCount) by type

重要なスタック情報の大部分は既に個別の変数に抽出されていますが、details 構造を分析してさらに詳細な情報を取得できます。 この構造は動的なので、期待する型に結果をキャストする必要があります。 次に例を示します。

exceptions
| extend method2 = tostring(details[0].parsedStack[1].method)

例外を関連する要求に関連付けるには、結合を使用します。

exceptions
| join (requests) on operation_Id

TrackTrace

TrackTrace を使用すると、Application Insights に「階層リンクの軌跡」を送信して問題を診断するときに役立ちます。 診断データのチャンクを送信し、診断検索で検査できます。

.NET ログ アダプターでは、この API を使用してポータルにサードパーティのログを送信します。

Java では、Application Insights Java エージェントによってログが自動収集され、ポータルに送信されます。

C#

telemetry.TrackTrace(message, SeverityLevel.Warning, properties);

Java

telemetry.trackTrace(message, SeverityLevel.Warning, properties);

Node.js

telemetry.trackTrace({
    message: message,
    severity: applicationInsights.Contracts.SeverityLevel.Warning,
    properties: properties
});

クライアント/ブラウザー側の JavaScript

trackTrace({
    message: string,
    properties?: {[string]:string},
    severityLevel?: SeverityLevel
})

メソッドの出入りなどの診断イベントをログに記録します。

パラメーター 説明
message 診断データ。 名前よりはるかに長くなることがあります。
properties 文字列と文字列のマップ。 ポータルで例外をフィルター処理するために多くのデータが使用されます。 既定値は空です。
severityLevel サポートされる値: SeverityLevel.ts

メッセージ コンテンツで検索できますが、プロパティ値とは異なりフィルター処理はできません。

message のサイズ制限は、プロパティの制限よりも非常に高くなっています。 TrackTrace の利点は、比較的長いデータをメッセージの中に配置できることです。 たとえば、メッセージ中で POST データをエンコードできます。

メッセージに重大度レベルを追加することもできます。 また他のテレメトリと同様、プロパティ値を追加することで、さまざまなトレースの組み合わせをフィルタリングしたり検索したりすることができます。 次に例を示します。

C#

var telemetry = new Microsoft.ApplicationInsights.TelemetryClient();
telemetry.TrackTrace("Slow database response",
                SeverityLevel.Warning,
                new Dictionary<string,string> { {"database", db.ID} });

Java

Map<String, Integer> properties = new HashMap<>();
properties.put("Database", db.ID);
telemetry.trackTrace("Slow Database response", SeverityLevel.Warning, properties);

この後に Search で、特定のデータベースに関連し特定の重大度レベルを持つすべてのメッセージを簡単に抽出することができます。

Log Analytics のトレース

Application Insights Analytics では、TrackTrace への呼び出しは traces テーブルに表示されます。

サンプリングが実行中の場合は、itemCount プロパティは 1 より大きい値を示します。 たとえば itemCount==10trackTrace() への 10 回の呼び出しで、サンプリング プロセスはそれらのうちの 1 つだけを転送したことを意味します。 トレース呼び出しの正しい数を取得するには、traces | summarize sum(itemCount) などのコードを使用します。

TrackDependency

応答時間と外部コードの呼び出しの成功率を追跡するには、TrackDependency 呼び出しを使用します。 結果は、ポータルの依存関係グラフに表示されます。 依存関係呼び出しが行われるたびに、以下のコード スニペットを追加する必要があります。

注意

.NET および .NET Core の場合は、関連付けに必要な DependencyTelemetry プロパティと、開始時刻や期間などの他のプロパティを設定する TelemetryClient.StartOperation (拡張機能) メソッドを代わりに使用できるため、下の例のようにカスタム タイマーを作成する必要はありません。 詳細については、「Application Insights .NET SDK でカスタム操作を追跡する」の「出力方向の依存関係の追跡」セクションを参照してください。

C#

var success = false;
var startTime = DateTime.UtcNow;
var timer = System.Diagnostics.Stopwatch.StartNew();
try
{
    success = dependency.Call();
}
catch(Exception ex)
{
    success = false;
    telemetry.TrackException(ex);
    throw new Exception("Operation went wrong", ex);
}
finally
{
    timer.Stop();
    telemetry.TrackDependency("DependencyType", "myDependency", "myCall", startTime, timer.Elapsed, success);
}

Java

boolean success = false;
Instant startTime = Instant.now();
try {
    success = dependency.call();
}
finally {
    Instant endTime = Instant.now();
    Duration delta = Duration.between(startTime, endTime);
    RemoteDependencyTelemetry dependencyTelemetry = new RemoteDependencyTelemetry("My Dependency", "myCall", delta, success);
    dependencyTelemetry.setTimeStamp(startTime);
    telemetry.trackDependency(dependencyTelemetry);
}

Node.js

var success = false;
var startTime = new Date().getTime();
try
{
    success = dependency.Call();
}
finally
{
    var elapsed = new Date() - startTime;
    telemetry.trackDependency({
        dependencyTypeName: "myDependency",
        name: "myCall",
        duration: elapsed,
        success: success
    });
}

サーバー SDK には、データベースや REST API などに対する依存関係の呼び出しを自動的に検出して追跡する依存関係モジュールが含まれています。 このモジュールを機能させるには、サーバーにエージェントをインストールする必要があります。

Java では、Application Insights Java エージェントを使用して、多くの依存関係呼び出しを自動的に追跡することができます。

この呼び出しは、自動追跡ではキャッチされない呼び出しを追跡する場合に使用します。

C# の標準の依存関係追跡モジュールを無効にするには、ApplicationInsights.config を編集し、DependencyCollector.DependencyTrackingTelemetryModule への参照を削除します。 Java の場合は、「特定の自動収集テレメトリの抑制」を参照してください。

Log Analytics での依存関係

Application Insights Analytics では、trackDependency 呼び出しは dependencies テーブルに表示されます。

サンプリングが実行中の場合は、itemCount プロパティは 1 より大きい値を示します。 たとえば itemCount==10trackDependency() への 10 回の呼び出しで、サンプリング プロセスはそれらのうちの 1 つだけを転送したことを意味します。 ターゲット コンポーネント別にセグメント化された依存関係の正しい数を取得するには、次のようなコードを使用します。

dependencies
| summarize sum(itemCount) by target

依存関係を関連する要求に関連付けるには、結合を使用します。

dependencies
| join (requests) on operation_Id

データのフラッシュ

通常、SDK からは一定の間隔 (通常 30 秒) で、またはバッファがいっぱいになったとき (通常 500 項目) にデータが送信されます。 場合によっては、バッファーをフラッシュする必要があります。 たとえば、シャットダウンするアプリケーションで SDK を使用している場合です。

.NET

Flush() を使用する場合は、このパターンをお勧めします。

telemetry.Flush();
// Allow some time for flushing before shutdown.
System.Threading.Thread.Sleep(5000);

FlushAsync() を使用する場合は、このパターンをお勧めします。

await telemetryClient.FlushAsync()
// No need to sleep

テレメトリが失われないように、常にアプリケーション シャットダウンの一部としてフラッシュすることをお勧めします。

Java

telemetry.flush();
//Allow some time for flushing before shutting down
Thread.sleep(5000);

Node.js

telemetry.flush();

サーバー テレメトリ チャネルの場合、この関数は非同期です。

Note

Java SDK と JavaScript SDK では、アプリケーションのシャットダウン時に自動的にフラッシュが実行されます。

認証されたユーザー

Web アプリでは、ユーザーは既定で、Cookie により識別されます。 ユーザーは、別のコンピューターまたはブラウザーからアプリにアクセスしたり、Cookie を削除した場合、複数回カウントされることがあります。

ユーザーがアプリにサインインしていれば、認証されたユーザーの ID をブラウザー コードに設定して、より正確な数値を取得できます。

JavaScript

// Called when my app has identified the user.
function Authenticated(signInId) {
    var validatedId = signInId.replace(/[,;=| ]+/g, "_");
    appInsights.setAuthenticatedUserContext(validatedId);
    ...
}

ASP.NET Web MVC アプリケーションでの例:

Razor

@if (Request.IsAuthenticated)
{
    <script>
        appInsights.setAuthenticatedUserContext("@User.Identity.Name
            .Replace("\\", "\\\\")"
            .replace(/[,;=| ]+/g, "_"));
    </script>
}

ユーザーの実際のサインイン名を使用する必要はありません。 必要なのは、そのユーザーに一意の ID であるということだけです。 ID には、スペースや ,;=| を含めることはできません。

ユーザー ID はセッション Cookie にも設定され、サーバーに送信されます。 サーバー SDK がインストールされている場合、認証されたユーザー ID は、クライアントおよびサーバー テレメトリの両方のコンテキスト プロパティの一部として送信されます。 送信後、フィルター処理や検索を行うことができます。

アカウントにアプリのグループ ユーザーがある場合、アカウントの識別子も渡すことができます。 同じ文字制限が適用されます。

appInsights.setAuthenticatedUserContext(validatedId, accountId);

メトリックス エクスプローラーで、ユーザー、認証アカウントユーザー アカウントをカウントするグラフを作成できます。

また、特定のユーザー名とアカウントを持つクライアント データ ポイントを検索することもできます。

注意

.NET Core SDK の ApplicationInsightsServiceOptions クラスの EnableAuthenticationTrackingJavaScript プロパティを使用すると、Application Insights JavaScript SDK によって送信される各トレースの認証 ID としてユーザー名を挿入するために必要な JavaScript 構成が簡略化されます。

このプロパティを true に設定した場合、ASP.NET Core ユーザーのユーザー名がクライアント側のテレメトリとともに出力されます。 このため、SDK for ASP.NET Core によって appInsights.setAuthenticatedUserContext は既に挿入され、手動で追加する必要がなくなります。 認証 ID は、JavaScript API リファレンスで説明されているように、サーバーにも送信され、そこで、.NET CORE の SDK によって識別され、サーバー側のテレメトリに使用されます。

SPA Web アプリなど、ASP.NET Core MVC と同じ方法で動作しない JavaScript アプリケーションの場合は、引き続き、appInsights.setAuthenticatedUserContext を手動で追加する必要があります。

プロパティを使用してデータをフィルター処理、検索、分割する

プロパティと測定値をイベント、メトリック、ページ ビュー、例外、その他のテレメトリ データにアタッチすることができます。

プロパティ は、利用状況レポートでテレメトリをフィルター処理するのに使用できる文字列値です。 たとえば、アプリケーションで複数のゲームを提供する場合、各イベントにゲームの名前を結び付けることで人気のあるゲームを確認できます。

文字列の長さには 8,192 の制限があります。 データの大きなチャンクを送信する場合は、TrackTrace のメッセージ パラメーターを使用します。

メトリックスはグラフィカルに表示できる数値です。 たとえば、ゲーマーが達成するスコアに漸増があるかどうかを確認できます。 イベントともに送信されるプロパティ別にグラフをセグメント化し、ゲームごとの個別のグラフや積み重ねグラフを表示できます。

正しく表示するには、メトリック値が 0 以上である必要があります。

使用できる プロパティ、プロパティ値、およびメトリックの数には制限 があります。

JavaScript

appInsights.trackEvent({
  name: 'some event',
  properties: { // accepts any type
    prop1: 'string',
    prop2: 123.45,
    prop3: { nested: 'objects are okay too' }
  }
});

appInsights.trackPageView({
  name: 'some page',
  properties: { // accepts any type
    prop1: 'string',
    prop2: 123.45,
    prop3: { nested: 'objects are okay too' }
  }
});

C#

// Set up some properties and metrics:
var properties = new Dictionary <string, string>
    {{"game", currentGame.Name}, {"difficulty", currentGame.Difficulty}};
var metrics = new Dictionary <string, double>
    {{"Score", currentGame.Score}, {"Opponents", currentGame.OpponentCount}};

// Send the event:
telemetry.TrackEvent("WinGame", properties, metrics);

Node.js

// Set up some properties and metrics:
var properties = {"game": currentGame.Name, "difficulty": currentGame.Difficulty};
var metrics = {"Score": currentGame.Score, "Opponents": currentGame.OpponentCount};

// Send the event:
telemetry.trackEvent({name: "WinGame", properties: properties, measurements: metrics});

Visual Basic

' Set up some properties:
Dim properties = New Dictionary (Of String, String)
properties.Add("game", currentGame.Name)
properties.Add("difficulty", currentGame.Difficulty)

Dim metrics = New Dictionary (Of String, Double)
metrics.Add("Score", currentGame.Score)
metrics.Add("Opponents", currentGame.OpponentCount)

' Send the event:
telemetry.TrackEvent("WinGame", properties, metrics)

Java

Map<String, String> properties = new HashMap<String, String>();
properties.put("game", currentGame.getName());
properties.put("difficulty", currentGame.getDifficulty());

Map<String, Double> metrics = new HashMap<String, Double>();
metrics.put("Score", currentGame.getScore());
metrics.put("Opponents", currentGame.getOpponentCount());

telemetry.trackEvent("WinGame", properties, metrics);

Note

プロパティで個人を特定できる情報を記録しないようにしてください。

プロパティとメトリックを設定する別の方法

個別のオブジェクトでイベントのパラメーターを集めたほうが便利であれば、そのようにできます。

var event = new EventTelemetry();

event.Name = "WinGame";
event.Metrics["processingTime"] = stopwatch.Elapsed.TotalMilliseconds;
event.Properties["game"] = currentGame.Name;
event.Properties["difficulty"] = currentGame.Difficulty;
event.Metrics["Score"] = currentGame.Score;
event.Metrics["Opponents"] = currentGame.Opponents.Length;

telemetry.TrackEvent(event);

警告

Track*() を複数回呼び出すために、同じテレメトリ項目インスタンス (この例では event) を再利用しないでください。 これを行うと、正しくない構成でテレメトリが送信される場合があります。

Log Analytics でのカスタム測定とプロパティ

Log Analytics では、カスタム メトリックとプロパティは、各テレメトリ レコードの customMeasurements および customDimensions 属性に表示されます。

たとえば、要求テレメトリに "game" というプロパティを追加する場合、このクエリは "game" のさまざまな値の出現数をカウントし、カスタム メトリック "score" の平均を表示します。

requests
| summarize sum(itemCount), avg(todouble(customMeasurements.score)) by tostring(customDimensions.game)

次のことに注意してください。

  • customDimensions または customMeasurements JSON から値を抽出する場合、それは動的な型であるため、tostring または todouble にキャストする必要があります。
  • サンプリングの可能性について考慮するには、count() ではなく、sum(itemCount) を使用します。

タイミング イベント

アクションの実行にかかる時間をグラフで示す必要が生じることがあります。 たとえば、ユーザーがゲームで選択肢について考える時間について調べるとします。 この情報を取得するには、測定パラメーターを使用します。

C#

var stopwatch = System.Diagnostics.Stopwatch.StartNew();

// ... perform the timed action ...

stopwatch.Stop();

var metrics = new Dictionary <string, double>
    {{"processingTime", stopwatch.Elapsed.TotalMilliseconds}};

// Set up some properties:
var properties = new Dictionary <string, string>
    {{"signalSource", currentSignalSource.Name}};

// Send the event:
telemetry.TrackEvent("SignalProcessed", properties, metrics);

Java

long startTime = System.currentTimeMillis();

// Perform timed action

long endTime = System.currentTimeMillis();
Map<String, Double> metrics = new HashMap<>();
metrics.put("ProcessingTime", (double)endTime-startTime);

// Setup some properties
Map<String, String> properties = new HashMap<>();
properties.put("signalSource", currentSignalSource.getName());

// Send the event
telemetry.trackEvent("SignalProcessed", properties, metrics);

カスタム テレメトリの既定のプロパティ

記述するカスタム イベントにいくつかに既定のプロパティ値を設定する場合、TelemetryClient インスタンスで設定できます。 それらは、そのクライアントから送信されたすべてのテレメトリ項目にアタッチされます。

C#

using Microsoft.ApplicationInsights.DataContracts;

var gameTelemetry = new TelemetryClient();
gameTelemetry.Context.GlobalProperties["Game"] = currentGame.Name;
// Now all telemetry will automatically be sent with the context property:
gameTelemetry.TrackEvent("WinGame");

Visual Basic

Dim gameTelemetry = New TelemetryClient()
gameTelemetry.Context.GlobalProperties("Game") = currentGame.Name
' Now all telemetry will automatically be sent with the context property:
gameTelemetry.TrackEvent("WinGame")

Java

import com.microsoft.applicationinsights.TelemetryClient;
import com.microsoft.applicationinsights.TelemetryContext;
...

TelemetryClient gameTelemetry = new TelemetryClient();
TelemetryContext context = gameTelemetry.getContext();
context.getProperties().put("Game", currentGame.Name);

gameTelemetry.TrackEvent("WinGame");

Node.js

var gameTelemetry = new applicationInsights.TelemetryClient();
gameTelemetry.commonProperties["Game"] = currentGame.Name;

gameTelemetry.TrackEvent({name: "WinGame"});

個別のテレメトリの呼び出しはプロパティ ディクショナリの既定値をオーバーライドできます。

JavaScript Web クライアントの場合、JavaScript テレメトリ初期化子を使用します。

標準コレクション モジュールのデータなど、すべてのテレメトリにプロパティを追加するには、ITelemetryInitializer を実装します

テレメトリのサンプル、フィルター、処理

Application Insights SDK におけるフィルター処理および前処理」を参照してください。

遠隔測定を無効にする

テレメトリの収集と送信を 動的に停止および開始 するには

C#

using  Microsoft.ApplicationInsights.Extensibility;

TelemetryConfiguration.Active.DisableTelemetry = true;

Java

telemetry.getConfiguration().setTrackingDisabled(true);

パフォーマンス カウンター、HTTP 要求、依存関係など、"選択されている標準のコレクターを無効にする" には、ApplicationInsights.config 内の該当する行を削除するか、コメント アウトします。たとえば、独自の TrackRequest データを送信する場合にこれを行います。

Node.js

telemetry.config.disableAppInsights = true;

初期化時にパフォーマンス カウンター、HTTP 要求、依存関係などの "選択されている標準コレクターを無効にする" には、構成メソッドを SDK の初期化コードにチェーンします。

applicationInsights.setup()
    .setAutoCollectRequests(false)
    .setAutoCollectPerformance(false)
    .setAutoCollectExceptions(false)
    .setAutoCollectDependencies(false)
    .setAutoCollectConsole(false)
    .start();

初期化後にこれらのコレクターを無効にするには、構成オブジェクト applicationInsights.Configuration.setAutoCollectRequests(false) を使用します。

開発者モード

デバッグ中、結果をすぐに確認できるように、テレメトリをパイプラインから送信すると便利です。 テレメトリで問題を追跡する際に役立つ他のメッセージも取得できます。 アプリケーションの速度を低下させる可能性があるため、実稼働ではオフにしてください。

C#

TelemetryConfiguration.Active.TelemetryChannel.DeveloperMode = true;

Visual Basic

TelemetryConfiguration.Active.TelemetryChannel.DeveloperMode = True

Node.js

Node.js の場合は、setInternalLogging 経由で内部ログを有効にし、maxBatchSize0 に設定することによって開発者モードを有効にすることができます。これにより、テレメトリは、収集されるとすぐに送信されます。

applicationInsights.setup("ikey")
  .setInternalLogging(true, true)
  .start()
applicationInsights.defaultClient.config.maxBatchSize = 0;

選択したカスタム テレメトリにインストルメンテーション キーを設定する

C#

var telemetry = new TelemetryClient();
telemetry.InstrumentationKey = "---my key---";
// ...

動的なインストルメンテーション キー

開発、テスト、運用の各環境のテレメトリが混じらないようにするために、環境に応じて個別の Application Insights リソースを作成し、それぞれのキーを変更できます。

インストルメンテーション キーは構成ファイルから取得する代わりにコードで設定できます。 ASP.NET サービスの global.aspx.cs など、初期化メソッドでキーを設定します。

C#

protected void Application_Start()
{
    Microsoft.ApplicationInsights.Extensibility.
    TelemetryConfiguration.Active.InstrumentationKey =
        // - for example -
        WebConfigurationManager.Settings["ikey"];
    ...
}

JavaScript

appInsights.config.instrumentationKey = myKey;

Web ページでは、スクリプトに一語一語コーディングする代わりに、Web サーバーの状態から設定することもできます。 たとえば、ASP.NET アプリで生成される Web ページでは次のように設定します。

Razor の JavaScript

<script type="text/javascript">
// Standard Application Insights webpage script:
var appInsights = window.appInsights || function(config){ ...
// Modify this part:
}({instrumentationKey:
    // Generate from server property:
    @Microsoft.ApplicationInsights.Extensibility.
        TelemetryConfiguration.Active.InstrumentationKey;
}) // ...
    String instrumentationKey = "00000000-0000-0000-0000-000000000000";

    if (instrumentationKey != null)
    {
        TelemetryConfiguration.getActive().setInstrumentationKey(instrumentationKey);
    }

TelemetryContext

TelemetryClient には、すべてのテレメトリ データとともに送信される値が含まれる Context プロパティが備わっています。 通常、標準のテレメトリ モジュールによって設定されますが、自分で設定することもできます。 次に例を示します。

telemetry.Context.Operation.Name = "MyOperationName";

いずれかの値を自分で設定した場合は、その値と標準の値が混同されないように、ApplicationInsights.config から該当する行を削除することを検討します。

  • Component:アプリそのバージョン。
  • Device:アプリが実行されているデバイスに関するデータ Web アプリでは、テレメトリを送信するサーバーまたはクライアント デバイスです。
  • InstrumentationKey:テレメトリが表示される Azure 内の Application Insights リソース。 これは通常、ApplicationInsights.config から取得します。
  • [場所] :デバイスの地理的な場所。
  • Operation:Web アプリでは現在の HTTP 要求。 他の種類のアプリケーションでは、イベントをグループ化するために、これを設定できます。
    • ID: 診断検索でイベントを調べるときに関連項目を見つけることができるように、さまざまなイベントを関連付けるために生成される値。
    • Name:識別子。通常は HTTP 要求の URL です。
    • SyntheticSource:null 値または空ではない場合に、要求元がロボットまたは Web テストとして識別されたことを示す文字列。 既定で、メトリックス エクスプローラーの計算から除外されます。
  • セッション:ユーザーのセッション。 ID は生成された値に設定されますが、ユーザーがしばらくの間アクティブでない場合には変更されます。
  • [ユーザー] :ユーザー情報。

制限

アプリケーションごと (インストルメンテーション キーごと) のメトリックとイベントの数には制限があります。 制限は、選択する料金プランによって異なります。

リソース 既定の制限 上限 Notes
1 日あたりの合計データ量 100 GB サポートにお問い合わせください。 上限を設定してデータを減らすことができます。 さらにデータが必要な場合は、ポータルで上限を最大 1,000 GB まで引き上げることができます。 1,000 GB を超える容量については、AIDataCap@microsoft.com までメールでご連絡ください。
Throttling 32,000 イベント/秒 サポートにお問い合わせください。 制限は 1 分間にわたって測定されます。
データ保持ログ 30 日 - 730 日 730 日 このリソースはログ用です。
データ保持メトリック 90 日間 90 日間 このリソースはメトリックス エクスプローラー用です。
可用性の複数手順のテストの詳細な結果の保持 90 日間 90 日間 このリソースは、各手順の詳細な結果を提供します。
テレメトリ項目の最大サイズ 64 KB 64 KB
バッチあたりの最大テレメトリ項目数 64,000 64,000
プロパティとメトリック名の長さ 150 150 型スキーマに関するページを参照してください。
プロパティ値の文字列の長さ 8,192 8,192 型スキーマに関するページを参照してください。
トレースおよび例外のメッセージ長 32,768 32,768 型スキーマに関するページを参照してください。
Application Insights リソースあたりの可用性テスト 100 100
プロファイラースナップショットのデータ保有期間 2 週間 サポートにお問い合せください。 保持の最大限度は 6 か月です。
プロファイラーの 1 日あたりの送信データ 制限なし 制限なし。
スナップショットの 1 日あたりの送信データ 監視対象アプリごとに 1 日あたり 30 のスナップショット 制限なし。 アプリケーションあたりに収集されるスナップショットの数は、構成することで変更できます。

価格とクォータの詳細については、「Application Insights の課金」を参照してください。

データ速度の上限に達するのを回避するには、サンプリングを使用します。

データの保持期間を確認する方法については、データの保持とプライバシーに関するページを参照してください。

リファレンス ドキュメント

SDK コード

よく寄せられる質問

このセクションでは、一般的な質問への回答を示します。

テレメトリ データが見つからないのはなぜですか?

アプリケーションがシャットダウンする前にフラッシュされていない場合、両方のテレメトリ チャネルでバッファリングされたテレメトリが消失します。

データの損失を回避するには、アプリケーションのシャットダウン時に TelemetryClient をフラッシュします。

詳細については、「データのフラッシュ」を参照してください。

Track_() 呼び出しでは、どのような例外がスローされることがありますか。

[なし] : try catch 句で例外をラップする必要はありません。 SDK で問題が発生すると、デバッグ コンソール出力のメッセージが記録されます。メッセージがスルーされる場合は、診断検索にも記録されます。

ポータルからデータを取得する REST API はありますか。

はい、データ アクセス API があります。 データを抽出するその他の方法としては、ワークスペース ベースのリソースに移行した場合は Power BI、クラシック リソースをまだ使用している場合は連続エクスポートなどがあります。

カスタム イベントとメトリック API の呼び出しが無視される理由は?

Application Insights SDK は、自動インストルメンテーションと互換性がありません。 自動インストルメンテーションが有効になっている場合、Track() やその他のカスタム イベントとメトリック API への呼び出しは無視されます。

Azure portal の App Service ページの [Application Insights] タブで自動インストルメンテーションをオフにするか、ApplicationInsightsAgent_EXTENSION_VERSIONdisabled に設定します。

検索グラフとメトリック グラフで数が等しくないのはなぜですか?

サンプリングにより、アプリからポータルに送信されるテレメトリ項目 (要求、カスタム イベントなど) の数が減少します。 [検索] には、受信した項目の数が表示されます。 イベント数を表示するメトリック グラフには、発生した元のイベントの数が表示されます。

送信される各項目には、itemCount プロパティが含まれます。このプロパティは、項目が表す元のイベントの数を示します。 Log Analytics で次のクエリを実行すると、サンプリング操作を確認できます。

    requests | summarize original_events = sum(itemCount), transmitted_events = count()

イベントにアラートを設定するには、どうすればよいですか?

Azure アラートはメトリックにのみ設定できます。 イベントが発生するたびにしきい値を超える、カスタム メトリックを作成してください。 その後、メトリックにアラートを設定します。 メトリックがどちらの方向であれしきい値を超えると、必ず通知を受け取ります。 初期値が高くても低くても、最初に超えるまでは通知を受け取りません。 常に数分の待ち時間が発生します。

次のステップ