• /
  • ログイン
  • 無料アカウント

ディストリビューティッド (分散) トレーシングの概要

ディストリビューティッド(分散)トレーシングは、ディストリビューティッド(分散)システムを通過するサービスリクエストを追跡し、監視します。ディストリビューティッド(分散)トレーシングデータを使用すると、障害やパフォーマンスの問題をすばやく特定して修正できます。

ディストリビューティッド(分散)トレーシングは、リクエストが1つのサービスから別のサービスに送られるたびにデータを収集し、ジャーニーの各セグメントをスパンとして記録します。これらのスパンは、リクエストの各セグメントに関する重要な詳細を含んでおり、1つのトレースにまとめられます。完了したトレースには、リクエスト全体の画像が表示されます。

ディストリビューティッド(分散)トレースでスパンがどのように生成されるかを示す図

これは、エージェントが各サービスに費やす時間を測定するウェブトランザクションの例です。エージェントはそのタイミング情報をスパンとしてNew Relicに送信し、そこで1つのディストリビューティッド(分散)トレースに結合します。

重要な理由

リクエストは、さまざまなマイクロサービスを通過して完了に達する可能性があります。マイクロサービスまたは機能は、複数のコンテナ、サーバーレス環境、仮想マシン、異なるクラウドプロバイダー、オンプレミス、またはこれらの任意の組み合わせに配置できます。

たとえば、実行速度の遅いリクエストが顧客のエクスペリエンスに影響する状況にあるとします。

  • リクエストは複数のマイクロサービスとサーバーレス機能に分散されます。
  • いくつかの異なるチームが、リクエストに関連するさまざまなサービスを所有し、監視します。
  • マイクロサービスに関するパフォーマンスの問題を報告したチームはありません。

さまざまなサービスにわたるリクエスト全体のパフォーマンスを表示する方法がなければ、高いレイテンシが発生している場所と理由、および問題に対処する必要があるチームを突き止めることはほぼ不可能です。

インストゥルメンテーション:ディストリビューティッド(分散)トレーシングの鍵

ディストリビューティッド(分散)トレーシングは、サービスのインストゥルメンテーションから開始し、分散型システム全体のデータ収集と相関を可能にします。インストゥルメンテーションとは、サービスに手動でコードを追加するか、トレースデータを自動的に追跡するエージェントをインストールするかのいずれかになります。

当社のNew Relicソリューションの多くは、多数のプログラミング言語とフレームワーク向けに、お客様のサービスを自動的にインストゥルメントします。また、オープンソースツールとオープンインストゥルメンテーションスタンダードを使用して、環境をインストゥルメントすることもできます。Cloud Native Computing Foundation(CNCF)の一部であるOpenTelemetryは、オープンソースのインストゥルメンテーションおよびテレメトリ収集の1つの標準になりつつあります。

New Relic UIに表示される内容

データを収集した後、データを視覚化して、サービスの依存関係、パフォーマンス、エラーや異常レイテンシなどの異常なイベントを確認できます。以下は、データを使用して実行できる操作の例です。

行えること

説明

異常なスパンの検知

代表的なパフォーマンスとの比較チャートを示した上で、一般的な行動と比較して遅いスパンは異常であるとマークされます。

エラーとログの表示

フロントエンドとバックエンドのエラーは、トレースのコンテキストで正しく表示されます。トラブルシューティングに必要なツールはすべて1か所にあります。

結果の絞り込み

多くのデータポイントを使用してチャートを絞り込み、さまざまな方法でトレースデータを分析できます。

クエリとダッシュボードのカスタマイズ

トレースデータのカスタムクエリを作成し、カスタムデータダッシュボードを作成することもできます。

複数のアカウントにわたる表示

New Relic Oneでは、全てのアカウントとアプリケーションにまたがるトレースの包括的なビューを表示できます。

プログラミングによるトレースのクエリ

NerdGraph APIエクスプローラーでGraphQLを使用して、ディストリビューティッド(分散)トレーシングデータのクエリを行います。

次のステップ

検討すべきいくつかのタスクは次のとおりです。

その他のヘルプ

さらに支援が必要な場合は、これらのサポートと学習リソースを確認してください:

問題を作成するこのページを編集する
Copyright © 2020 New Relic Inc.