LoginSignup
1
0

Node-RED + Datadog でWEBアプリ制作に挑戦

Last updated at Posted at 2024-05-31

こんな使い方する人はたぶん世界で私だけ...

Datadog でWEBアプリ制作に挑戦した話です

Datadogは本来、サーバーやクラウドを監視・モニタリングしてIT運用するためのオブザーバビリティサービスであり、DatadogでWEBアプリを制作する人はいないと思います。Datadog で何か楽しいことができないかなと新しい使い方を導くためにWEBアプリの制作に挑戦してみました。

image.png

Datadog: Free 料金プラン

Datadog は最大5台までのサーバーと1日間のメトリックスを保持できるずうっと無料のプランが用意されています。また、サインアップしたら14日間は全ての機能を無制限に試すことができます。この無料プランで挑戦します。

完成イメージ

アンケート投稿はスマホ画面、アンケート集計結果はPC画面サイズを想定しています。

image.png

アプリ構成

アンケート投稿アプリは仮想サーバーのNode-REDで制作し、アンケート集計をDatadogダッシュボードで実行します。
image.png

投票したアンケートの値がログファイルを経由して、Datadogインテークサーバーに送られて監視メトリックとなり、それを集計することでアンケートの投票結果とします。
image.png

(1)アンケート投稿アプリ

IBM Cloud 仮想サーバー(Ubuntu)でNode-REDを稼働させます。Node-REDのダッシュボード機能は、WEBブラウザでボタンやゲージ、グラフなどIoT向けのGUIを表示させることができます。

image.png

初期設定

  1. 仮想サーバー(Ubuntu)の立ち上げ
  2. Datadog Agent のインテグレーション
  3. Node-RED のインストール

仮想サーバー

image.png

IBM Cloud 仮想サーバーの最小スペックで安価に実行します。最小スペックは Classic 一時利用で1vCPU, 1GBメモリの時、1日あたり$0.24(円安160円/$)で換算して38円/日で利用可能。月額(744h)換算で1,190円から。ClassicはVPCやサブネット,VLANの初期設定が不要ですぐにインターネットに公開するWEBを立ち上げることができます。
本番用途なら VPC 仮想サーバー 2vCPU, 4GBメモリを月額割引の$80.22で利用可能。可用性は[自動再始動]を選ぶと、ホストとなる物理サーバーに障害が発生した場合は別の正常な物理サーバーに自動的に移行されて再始動してくれる。

image.png

Datadog インテグレーション

Docker Agent を起動するとすぐにメトリック取得が始まります。

image.png

Node-RED

IoTをローコードで開発できるツール。Node.jsが動く環境であれば IBM Cloud じゃなくてもどのクラウドでも動きます。ラズベリーパイでも動きます。Node-REDを起動したらフローを制作します。

image.png

ローコード開発

  1. Node-RED ダッシュボードに表示するボタンを配置。ボタンが押されたら、ログを出力するシェルスクリプト(sendmtrx.sh)をコーディング。実行権も付与する。
  2. WEBアプリは Node-REDダッシュボードで実行。ボタン[AWS]が押されたら[1]を引数にシェルスクリプトを呼び出す。ボタン[Azure]なら[2]を引数に以降、[5]まで続く。
  3. シェルスクリプトが呼ばれたら[1~5]の引数に対応するリストの[A]~[E]がログに出力される。Datadogエージェントはログファイルを監視しており、ログを取得したらDatadogインテークサーバーにテキストログを送信する。
  4. Datadog管理ポータルで Logs Pipelines を構築する。Logs Pipelines の Grok Parser 機能は、テキストログをパースしてJSON形式の値[例:kanoAnswer]を取得し、Generate Metrics でカスタムメトリック[例:Question.Answer]を生成できる。この時、カスタムメトリックには[A~E]の値が保持される。

image.png

(2)アンケート集計アプリ

Datadog ダッシュボードにメトリック集計結果を表示します。Metrics Explorer でカスタムメトリックの数を集計しました。この例では、一定時間内のカスタムメトリック[kanoAnswer]=[A]となる数を合計して[3]を表示しています。同様に[B]の合計は[4]個といった集計が続きます。

image.png

アンケートを実践する

Datadogユーザー会(JDDUG)の参加者30名近くがスマホでアンケートに回答。推しのクラウドを連打して、その場でアンケート集計まで自動実行できました! 回答数が3,000個近くあってすごい。
image.png

まとめ

  • IBM Cloud で稼働させた Node-RED でアンケート投稿アプリを作れました
  • Datadog でアンケート集計サーバーを作れました
  • 会場のみんなが元気玉のようにメトリック送信に協力くださり、ありがとうございました

全部で5,000個近くのメトリックを頂きました。ここではグーグルが一番人気でした。
image.png

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0