Grafanaの準備
influxDBをインストール
insluxDBをシステムにダウンロードします。
sudo apt-get install influxdb
sudo apt-get install influxdb-client
influxDBを起動します。
sudo systemctl start influxdb
データベースの設定
コマンドプロンプトからinfluxDBのCLIを立ち上げます。
influx
データベースを作成します。
作成したデータベース名をGrafana側でも設定します。
CREATE DATABASE test_database;
GrafanaにinfluxDBをセット
data:image/s3,"s3://crabby-images/727bc/727bc4f52fbd571c997a4047e516345a06adfaad" alt=""
画面左上の「≡」からConnectionsのAdd new conectionを開きます。
data:image/s3,"s3://crabby-images/19565/1956559efacccc430716bed5ff2988596ca42d1a" alt=""
influxDBを選択します。
data:image/s3,"s3://crabby-images/ee076/ee0767ffe1e9de9741221d264b3378b8de3643e9" alt=""
Add new data sourceをクリック。
data:image/s3,"s3://crabby-images/eeb67/eeb675e40a7c9efeaaf5bb7f23176a9ac7b7d546" alt=""
設定画面が開きます。
data:image/s3,"s3://crabby-images/e1494/e1494d468645b9c73074be85ed817917eaaba134" alt=""
Grafanaの実行元 IP のポート8086。
data:image/s3,"s3://crabby-images/dcfa7/dcfa734ea4b8ba1f3b5e8f25a3fac42336b5181b" alt=""
データベース名、User名・パスワードを入力。
data:image/s3,"s3://crabby-images/a922a/a922ad642b774e5a54f97e016e245e21d162562a" alt=""
GrafanaをさくらのVPSで開いているため、使用するポート8086のパケットフィルターを設定しておきました。
ダッシュボードのセット
data:image/s3,"s3://crabby-images/ef4e7/ef4e7af7ea72b4f17f56f9d2589a305beb030060" alt=""
画面左上の「≡」からDashboardsを開き、新規でダッシュボードを作成します。
data:image/s3,"s3://crabby-images/6ddc1/6ddc1f15f57760b6006018210641662355a8c42c" alt=""
Add visualizationを選択。
data:image/s3,"s3://crabby-images/e9f78/e9f78ab198f513a67a3a6bda4b8ae906b611d67f" alt=""
先ほど作成しておいた名前のinfluxDB(Test-influx)を選択します。
data:image/s3,"s3://crabby-images/d0b05/d0b050662eba403cd8ad56725b101aea0229a43b" alt=""
エディター画面に遷移したら、右上からsaveをしておきます。
Node REDの準備
node-red-contrib-influxdb のインストール
パレットからインストール、または https://flows.nodered.org/node/node-red-contrib-influxdb からCmdでインストール。
下記ノードが追加されます。
data:image/s3,"s3://crabby-images/1a96d/1a96d1115ba837173e7f25822c4ee5b53f2af2ce" alt=""
今回はNode RED側からinfluxDBにデータを送信するため、influxdb outを使用します。
フローの作成
data:image/s3,"s3://crabby-images/2ad7b/2ad7b22d7f6c342e0ca8ddaa2da152fabe8e6a22" alt=""
今回はランダムウォークのプログラムをfunctionノードで2秒間隔で走らせて、Grafanaに送信しています。
data:image/s3,"s3://crabby-images/558c7/558c7f47c21d35587647b3879f18723909bf9e95" alt=""
data:image/s3,"s3://crabby-images/dddff/dddffb503fe7f11d9dddeb4194a3866077d2629c" alt=""
influxDB 作成時に設定した test_database という名前のデータベースに、任意の名前のmeasurementに格納していきます。(今回はtest_measurement)
確認方法
data:image/s3,"s3://crabby-images/ce0bc/ce0bc657cd9f6f4c2e6de1bc61b840fc2af9ec01" alt=""
Grafana画面左上の「≡」からDashboardsを開き、作成したDashboardを選択します。
data:image/s3,"s3://crabby-images/8a832/8a832f8ba9d1f8c6b384dc641c890c00e3f87801" alt=""
Panelの「︙」からEditを選択しエディターを開きます。
data:image/s3,"s3://crabby-images/f45c6/f45c63634b29dd33cc17535fefe2078d9d91ec88" alt=""
今回payloadにvalueという名前でデータを格納したので、nodered_measurementのvalueというfieldを選択します。
data:image/s3,"s3://crabby-images/9fec8/9fec8ee2c258d99fa92876144e3699cc2e7ff174" alt=""
データが反映されていることがわかります。
画面右側でパネルの体裁など詳細設定ができます。
data:image/s3,"s3://crabby-images/3a9a8/3a9a81d86db2ac7a1bf43570c95d1eefd50ee4c8" alt=""
Applyすることで、選択したfieldのグラフを固定表示することができます。
同様にinfluxdb outノードにセンサデータ等を入れれば、簡単に可視化することができます。
フローデータ
[ { "id": "fef8886ba18fb157", "type": "inject", "z": "c836091b6da91e2f", "name": "", "props": [ { "p": "payload" }, { "p": "topic", "vt": "str" } ], "repeat": "2", "crontab": "", "once": false, "onceDelay": 0.1, "topic": "", "payload": "", "payloadType": "date", "x": 390, "y": 280, "wires": [ [ "3d92f004976a3abf" ] ] }, { "id": "3d92f004976a3abf", "type": "function", "z": "c836091b6da91e2f", "name": "ランダムウォーク", "func": "// ランダムウォークのプログラム\nfunction generateRandomWalk(currentValue) {\n // ランダムに+1または-1を選び、現在の値に加算する\n const step = Math.random() < 0.5 ? -1 : 1;\n return currentValue + step;\n}\n\n// メインのランダムウォーク関数\nfunction getRandomWalk() {\n // flow contextから現在の値を取得するか、初期値を設定\n let currentValue = flow.get(\"currentValue\") || 0;\n\n return function () {\n currentValue = generateRandomWalk(currentValue);\n\n // flow contextに現在の値を保存\n flow.set(\"currentValue\", currentValue);\n\n return currentValue;\n };\n}\n\n// ランダムウォーク関数のインスタンスを生成\nconst randomWalk = getRandomWalk();\n\n// ランダムウォークの値を生成してmsg.payloadに格納\nmsg.payload = {\n value: randomWalk()\n};\n\n// Node-RED上でメッセージを送信\nnode.send(msg);\n", "outputs": 1, "timeout": 0, "noerr": 0, "initialize": "", "finalize": "", "libs": [], "x": 610, "y": 280, "wires": [ [ "cc23d388aad7bce5" ] ] }, { "id": "cc23d388aad7bce5", "type": "influxdb out", "z": "c836091b6da91e2f", "influxdb": "a714e7a0ba5e0f1f", "name": "", "measurement": "nodered_measurement", "precision": "", "retentionPolicy": "", "database": "database", "precisionV18FluxV20": "ms", "retentionPolicyV18Flux": "", "org": "organisation", "bucket": "bucket", "x": 990, "y": 280, "wires": [] }, { "id": "a714e7a0ba5e0f1f", "type": "influxdb", "hostname": "[grafanaの実行先アドレス]", "port": "8086", "protocol": "http", "database": "test_database", "name": "", "usetls": false, "tls": "", "influxdbVersion": "1.x", "url": "http://localhost:8086", "timeout": "10", "rejectUnauthorized": true } ]