Node-RED 2.0の新機能: フローデバッガ
株式会社日立製作所
サービスコンピューティング研究部
西山博泰
はじめに
Node-REDはコーディングレスでプログラムを作成できるプログラミングツールです。このようなプログラミングはLow Code/No Codeプログラミングと呼ばれ、最近大きな注目を集めています。Node-REDは、IoT分野を筆頭に様々な分野で広く活用されているLow Codeプログラミングツールの一つです。
Node-REDでは、ノードと呼ばれる機能ブロックををつなぎ合わせることで、とても簡単にプログラムを作成することができます。こういったノードには、乱数生成など簡単なユーティリティノードから、SNSからの情報収集、今流行りの機械学習を行うためのノードなど様々なノードが存在し、それらはOSSノードとして多数公開されています。
2021年7月、Node-REDの最新版であるバージョン2.0がリリースされました。Node-RED 2.0では、アプリケーションの開発を容易化するさまざまな機能が新しく導入されました。一連の記事でNode-RED 2.0の新機能を紹介したいと思います。
この記事では、そのうちフローのデバッグを支援するための機能であるフローデバッガを紹介します。
フローデバッガ
Node-REDは使いやすいフローエディタを備えているため、プログラムの動作に不具合があった場合、フローの一部を修正して動作詳細の確認を容易に行うことができます。ただし、複雑なフローを修正しないで、その動作を確認したいというケースもあります。
フローデバッガは、他のプログラミング言語でのデバッガと同様に、Node-REDフローの実行を指定したポイントで停止し、処理状況を確認、実行を再開する機能を備えています。これにより、フローを修正しないでその詳細な動作を確認することができます。
インストール方法
Node-REDのフローデバッガは、Node-RED本体の基本機能ではなく、Node-RED 1.3で導入されたプラグイン機能を使った拡張機能です。ノードと同様に、追加インストール機能可能です。
フローデバッガのNode-REDへの機能追加方法は次の通りです。
-
エディタメニューの パレットの管理 → ノードを追加 から
node-red-debugger
を検索 -
「ノードを追加」ボタンで機能を追加します。
-
Node-REDを再起動します。
-
フローエディタ右のサイドバータブに「フローデバッガ」が追加されていることを確認します。
利用方法
サイドバーから「フローデバッガ」を選択すると、次のようなタブが表示されます。
左上のスイッチが初期状態では「無効」となっているので、フローデバッガの機能を利用する場合には「有効」に変更します。
-
ブレークポイントの設定
フローデバッガを有効にしている場合、ノードの入出力ポートにブレークポイントを設定することができます。ブレークポイントの設定は、ノードの入出力メッセージポートにマウスを重ねると、薄い水色の角丸矩形が表示されます。
マウスをクリックすると、ポート上の矩形が濃い水色に変化し、ポートにブレークポイントが設定されます。
現在設定されているブレークポイントのリストは「デバッガ」サイドバーに表示されます。このリストからブレークポイントの有効/無効の切り替え、削除を行うことができます。ブレークポイントとして指定されたにメッセージが到達すると、「デバッグ」サイドバーにメッセージの内容が表示されます。
停止メッセージの右、もしくは、サイドバーの上部に表示されるボタンを押すことで停止したフロー実行の再開・ステップ実行を行うことができます。
-
実行中フローの停止
「デバッグ」サイドバーの上部のストップボタンを押すと、実行中のフローを停止することができます。
停止したフローは、ブレークポイントで停止した場合と同様に、実行再開・ステップ実行を行うことができます。
なお、フロー中の各ノードは完全に停止しているわけではなく、ノード間のメッセージの送受信が停止した状態です。そのため、Injectノードの繰返し指定など、定期的なメッセージ出力を行うノードは、出力ポートにメッセージが蓄積されることになります。
デバッグの例
具体的な例を用いてフローデバッガを用いたデバッグの過程を紹介します。
ここでは、入力メッセージプロパティの加算を行う簡単なフローを例として用います。
以下は、加算対象の入力メッセージを出力するInjectノードの設定です。
changeノードはJSONata式を用いてペイロードのxプロパティとyプロパティを加算した結果を出力します。
このフローを実行してみると、debugノードの出力は次のようにundefined
となります。
確認のため、フローデバッガを用いて、changeノードの入力ポートにブレークポイントを設定し、フローを実行します。
入力メッセージを確認すると、payload
の値がオブジェクトではなく文字列となっていることがわかります。Injectノードの設定でpayload
の値がJSONオブジェクトではなく文字列となっているため、JSONオブジェクトに変更します。
フローを再実行すると、期待する値100
が出力されます。
おわりに
この記事ではNode-RED 2.0の新機能として「フローデバッガ」を紹介しました。フローデバッガは基本的なデバッグ機能をNode-REDに加えるものですが、Node-REDエディタの使い勝手の良さに加えてデバッグ機能がサポートされることで、フローの作成がさらに容易になることが期待されます。
Node-RED 2.0の新機能紹介
Node-RED: Node-REDは,OpenJS Foundationの米国およびその他の国における登録商標または商標である。
JavaScript: JavaScriptは、Oracleの米国およびその他の国における登録商標または商標である。