【Prometheus & Grafana】MetricFireでセットアップする方法


Prometheusは優れた監視ツールですが、一時的にメトリクスを保存し読み取るだけのものです。 つまり、長期間のデータを読み解きたい場合、Prometheusにメトリックをストレージソリューションに書き込ませる必要があります。 これが実現する時こそ、MetricFireの出番です。MetricFireは長期的なPrometheusストレージを実行できるPrometheusのマネージドサービスを提供しているため、メトリックのストレージのセットアップやメンテナンスについて心配する必要はありません。ユーザーはPrometheusの監視のみに集中できます。

MetricFireにはHosted Grafanaも付属しているため、メトリックスの可視化を設定する時間と手間がさらに省けます。 この記事では、MetricFireアカウントが必要です。 こちらをクリックすると、14日間の無料トライアルを取得できます。

Grafanaを使用して監視すると、最終的には次のようになります。

このチュートリアルに従って、どのように実行していくのかを確認してください。

MetricFireのPrometheus構成設定

無料トライアルにサインアップした後、MetricFireダッシュボードからAPIキー設定が必要になります。 この情報は、独自のPrometheusインストールのPrometheus構成ファイルに入れられます。 下の画像のように、MetricFireダッシュボードから、[Add on]> [Prometheus]に移動します。 このコードブロックは、この記事の後半で使用されます。

Promethuesをご使用したことがない場合は、以下を読み続けてください。 それ以外の場合は、「prometheus.ymlの変更」セクションまで、スキップしてください。

Prometheusのセットアップ

以下のチャートは、PrometheusがMetricFireと一緒に機能する方法の例を示しています。 ノードをPrometheusにセットアップし、PrometheusをMetricFireに転送するだけで、MetricFireがメトリックを読み書きできるようになります。

まず、Prometheusとノードエクスポーターをダウンロードします。 Prometheusサイトのダウンロードセクションに進んでください。

上の画像から赤い丸で囲まれた部分のリンクの場所を右クリックしてコピーし、ダウンロードURLを取得します。

curl -LO URL_FROM_LINKS_ABOVE

上記のコードスニペットを使用して、PrometheusをホストするマシンにPrometheusをダウンロードし、監視するマシンにノードエクスポーターをダウンロードします。 上記のコマンドで、「URL_FROM_LINKS_ABOVE」をPrometheusダウンロードセクションから取得したリンクに置き換えます。 下の画像の完全な例を確認してください。

次に、以下のコードスニペットを使用してtar.gzファイルを抽出します。

tar -xvf TAR_GZ_FILE_NAME

prometheus.ymlの変更

Prometheusを実行する前に、構成を編集して、いずれかのノードからメトリックを収集します。 次に、MetricFireにメトリックを送信して、Prometheusメトリックを格納および集約できるようにします。

まず、同じマシン上にある現在のノードをターゲットとするように.ymlファイルを変更します。 以下の画像のように、ifconfigを実行してIPアドレスを見つける必要があります。

次に、.ymlファイルに移動して、下の画像のように内容を編集します。

job_nameは、ノードがエクスポートするメトリックの種類にすることができ、ターゲットはノードのリストです。 以下のコードスニペットからコピーして貼り付け、JOB_NAMEとIP_FROM_IFCONFIGを適切に置き換えることができます。

global:
 scrape_interval: 5s
scrape_configs:
 - job_name: 'JOB_NAME'
   static_configs:
   - targets: ['IP_FROM_IFCONFIG:9100']

最後に、.ymlファイルについて、この記事の最初のビットから取得したコードブロックを追加しましょう。 MetricFireダッシュボードからカスタム構成コードスニペットを取得しました。その方法は、上記の「MetricFireのPrometheus構成設定」セクションで確認できます。 18〜24行目のコードのインデントについては、下の画像を確認してください。

PrometheusおよびNode Exporterの実行

すべての設定が完了したので、Prometheusとノードを実行します。 以前に入手した解凍したtar.gzファイルに移動します。 Prometheusフォルダーで./prometheusを実行し、node_exporterフォルダーで./node_exporterを実行します。

これで、メトリックスをMetricFireに送信し、メトリックスを格納して集約することができます。 最新のメトリックがいつPrometheusクライアントから送信されたかを確認できるMetricFireダッシュボードに移動して、機能しているかどうかを確認できます。 下の画像で丸で囲んであるのを見てください。

MetricFireでのGrafanaの使用
ノードを実行し、.ymlファイルを変更してノードとMetricFireをターゲットにし、Prometheusクライアントを実行したら、MetricFireアカウントにPrometheusメトリックを格納および集計する必要があります。

MetricFireにはHosted Grafanaが付属しているため、Prometheusメトリック用のより動的なダッシュボードを使用できます。 また、MetricFireはメトリックストレージを処理しているため、Prometheusメトリックは短期だけでなく長期のグラフを表示できます。

現在受け取っているCPUデータのダッシュボードを作成してみましょう。 下の画像のように、「+Add dashboard」に移動します。

そして、[Add query]

次に、下の画像のように、cpuの合計使用量にクエリを追加します。

以下のコードスニペットを使用してクエリに貼り付けると、どのように機能するかを確認できます。 システムとユーザーのみの合計CPUでirateを使用しています。

irate(node_cpu_seconds_total{mode=~"system|user"}[1m])

まとめ

このブログ投稿では、PrometheusとGrafanaをMetricFireで設定する方法を示しました。 MetricFireのHosted Prometheusは、すべてのユーザーのすべてのデータに対して3倍の冗長性で最大1年間メトリックを保存します。

クレジットカード不要の無料トライアルにサインアップして、開始してみてください。 また、デモを予約して、MetricFireチームにビデオ通話を依頼してください。 ユーザーがプラットフォームを最大限に活用できるようにサポートさせていただきます。

それでは、次の記事で!