ダッシュボードを作成して、APM メトリクスを追跡、関連付ける

4 分で読了

Datadog APM では、ビジネスの優先順位と重要なメトリクスに基づいてダッシュボードを作成できます。 このダッシュボードにウィジェットを作成して、従来のインフラストラクチャー、ログ、およびホストメモリ使用量などのカスタムメトリクスを、スループット、レイテンシー、相関のエラー率に基づく重要な APM メトリクスとともに追跡できます。 また、主要顧客のユーザーエクスペリエンスや最大のトランザクションを追跡したり、ブラックフライデーのような主要イベントに先駆けてメインウェブサーバーのスループットを追跡したりできます。

このガイドでは、トレースメトリクスをダッシュボードに追加し、それをインフラストラクチャーメトリクスと関連付けてから、Analytics クエリをエクスポートする方法について説明します。このガイドでは、以下の 3 つの方法でダッシュボードにウィジェットを追加する方法について説明します。

  • 既存の APM グラフをコピーする_(ステップ 1.、2.、3.)_
  • 手動で作成する。(ステップ 4.、5.)
  • Analytics クエリをエクスポートする。(ステップ 7.)
  1. **サービスカタログ**を開き、web-store サービスを選択します。

  2. Total Requests グラフを見つけ、右上の export ボタンをクリックして Export to Dashboard を選択します。New Timeboard をクリックします

    ダッシュボード 2
  3. 成功メッセージの View Dashboard をクリックします。

    新しいダッシュボードでは、web-store サービスの Hit/error count on service グラフが利用可能になりました。このサービスのスループット全体とエラーの合計量が表示されます。

    ダッシュボード 3

    : 鉛筆アイコンをクリックするとこのグラフを編集し、使用されている正確なメトリクスを確認できます。

  4. ダッシュボードスペースの Add graph プレースホルダータイルをクリックしてから、このスペースに Timeseries をドラッグします。

    これは、ダッシュボードウィジェットの編集画面です。ここでは、利用可能なすべてのメトリクスに対してあらゆるタイプの視覚化を作成できます。詳細については、時系列ウィジェットのドキュメントをご覧ください。

  5. system.cpu.user ボックスをクリックして、関連するメトリクスとパラメーターを選択します。この例では以下の通りです。

    パラメーター説明
    metrictrace.rack.requests.errorsRuby Rack の誤ったリクエストの合計セット。
    fromservice:web-storeこのサンプルスタックのメインサービス。これは Ruby サービスであり、チャート内のすべての情報はここから取得されます。
    sum byhttp.status_codehttp ステータスコードによるチャートの分類。

    この具体的な内訳は、選択できる多くの一例にすぎません。trace. で始まるメトリクスには APM 情報が含まれることに注意することが重要です。詳細については、APM メトリクスのドキュメントを参照してください。

  6. 別の時系列をプレースホルダータイルにドラッグします

    この例では、trace.*runtime.* という 2 種類のメトリクスがグラフに追加されます。これらのメトリクスを組み合わせることで、リクエストとコードランタイムパフォーマンス間の情報を関連付けることができます。具体的には、レイテンシーの急上昇はスレッドカウントの増加に伴って発生する可能性があることがわかっているため、スレッドカウントの横にサービスのレイテンシーが表示されます。

    1. まず、ウィジェットに trace.rack.requests.errors メトリクスを追加します。

      パラメーター説明
      metrictrace.rack.request.duration.by.service.99pサービスのリクエストのレイテンシーの 99 パーセンタイル。
      fromservice:web-storeこのサンプルスタックのメインサービス。これは Ruby サービスであり、チャート内のすべての情報はここから取得されます。
    2. 次に、Graph additional: Metrics をクリックして、チャートに別のメトリクスを追加します。

      パラメーター説明
      metricruntime.ruby.thread_countRuby ランタイムメトリクスから取得したスレッドカウント。
      fromservice:web-storeこのサンプルスタックのメインサービス。これは Ruby サービスであり、チャート内のすべての情報はここから取得されます。

    このセットアップでは、レイテンシーの急上昇が Ruby スレッドカウントの急上昇に関連しているかどうかを示すことができ、レイテンシーの原因をすぐに特定することで迅速な解決が可能になります。

  7. Analytics に移動します

    この例では、サンプルアプリケーション全体のレイテンシーをクエリする方法を示します。プラットフォーム上のマーチャント別に分類し、レイテンシーが最も高い上位 10 マーチャントを表示します。Analytics 画面から、グラフをダッシュボードにエクスポートしてそこでこれを表示します。

  8. ダッシュボードに戻ります

    複数のウィジェットが見られるようになり、技術的な観点とビジネス上の観点の両方からサンプルアプリケーションを深く観察できるようになりました。しかし、インフラストラクチャーメトリクスの追加、複数の種類の視覚化の使用、計算と予測の追加など、できることはまだまだあります。

    ダッシュボードを使用すれば、関連するイベントを調べることもできます。

  9. Search Events or Logs ボタンをクリックして、関連するイベントエクスプローラーの検索を追加します。: この例では Ansible が使用されていますが、イベントエクスプローラーは異なる場合があります。

    ダッシュボード 1

    ここでは、ダッシュボードのビューとともに、デプロイ、タスクの完了、モニターアラートなど、(Datadog または Ansible、Chef などの外部サービスで)発生した最近のイベントを確認できます。これらのイベントは、ダッシュボードで設定されたメトリクスで起こっていることと関連付けることができます。

    最後に、テンプレート変数を必ず使用してください。これは、すべてのユーザーがウィジェット自体を編集しなくても使用できるダッシュボード上のウィジェットを動的に制御する一連の値です。詳しくは、テンプレート変数のドキュメントを参照してください。

  10. ヘッダーの Add Variable をクリックします。変数が制御するタグを選択し、その名前、デフォルト値、または利用可能な値を構成します。

    この例では、ダッシュボードが 2 つの主要な操作領域である us-east1europe-west-4 でどのように動作するかを確認するために、Region のテンプレート変数が追加されています。

    変数名と変数タグを追加するフィールドオプションを表示する Add Variable ポップオーバー

    これで、このテンプレート変数を各グラフに追加できます。

    クエリに動的テンプレート変数を追加します。この例では、'$RG' を地域テンプレート変数に動的にスコープしています

    テンプレート変数値を選択すると、ダッシュボードの該当するウィジェットですべての値が更新されます。

    使用可能なメトリクスをすべて確認し、Datadog の可観測性の 3 本の柱を最大限に活用してください。この基本的なダッシュボードは、組織の監視と可観測性のためのワンストップショップである強力なツールに変換できます。

その他の参考資料