MQTT リテインドメッセージ
EMQX は MQTT のリテインドメッセージ機能を実装しています。特定のトピックでパブリッシュされたメッセージを Retained としてフラグを立て、EMQX 上に永続的なメッセージとして保存できます。新しいサブスクライバーがリテインドメッセージのトピックにサブスクライブすると、そのメッセージがすでにパブリッシュされていても即座に受信します。
クライアントツールを使って EMQX に接続し、このメッセージングサービスを試すことができます。本節では、MQTTX Desktop と MQTTX CLI を使ってクライアントをシミュレートし、リテインドメッセージのパブリッシュと受信の動作を確認する方法を紹介します。
前提条件
- MQTT の リテインドメッセージ に関する知識
- MQTTX を使った基本的なパブリッシュおよびサブスクライブ操作
MQTTX Desktop でリテインドメッセージをパブリッシュする
EMQX と MQTTX Desktop を起動します。New Connection をクリックして、パブリッシャーとしてクライアント接続を作成します。
- Name フィールドに
Demoと入力します。 - Host にローカルホストの
127.0.0.1を入力します(このデモの例として使用)。 - 他の設定はデフォルトのままにして、Connect をクリックします。
TIP
MQTT 接続の作成に関する詳細な手順は MQTTX Desktop を参照してください。

- Name フィールドに
接続が成功したら、テキストボックスにトピック名
sensor/t1を入力し、スクリーンショットのようにメッセージペイロードを作成します。送信ボタンをクリックしてください。トピックsensor/t1へのメッセージがメッセージダイアログに表示されます。
トピック
sensor/t2でリテインドメッセージを2つパブリッシュします。- 1つ目のメッセージに
1と入力し、Retain を選択して送信ボタンをクリックします。 - 2つ目のメッセージに
2と入力し、送信ボタンをクリックします。

- 1つ目のメッセージに
Connections ペインで + -> New Connection をクリックし、メッセージを受信するクライアントとしてサブスクライバー
Subscriberを作成します。+ New Subscription をクリックし、トピック
sensor/+にサブスクライブします。Confirm ボタンをクリックしてください。TIP
トピックを
sensor/+に設定すると、sensor/t1とsensor/t2の両方にサブスクライブされます。トピックとワイルドカードの詳細は Understanding MQTT Topics & Wildcards by Case をご覧ください。クライアント
Subscriberは、トピックsensor/t1の最初のメッセージや、トピックsensor/t2の最初のリテインドメッセージは受信せず、各トピックの最新のリテインドメッセージのみを受信します。これは EMQX が各トピックの最新のリテインドメッセージのみを保存しているためです。
これで MQTTX クライアントを使ってリテインドメッセージを送信する方法を試しました。EMQX ダッシュボードから保存されている最新のリテインドメッセージを確認することもできます。詳細は ダッシュボードでリテインドメッセージを確認する をご覧ください。
MQTTX CLI でリテインドメッセージをパブリッシュする
1つのクライアントで接続要求を開始します。
次のコマンドを使ってリテインドメッセージをパブリッシュします。トピックは
t/1、ペイロードはA retained message from MQTTX CLI、retain = trueに設定します:bashmqttx pub -t 't/1' -m 'A retained message from MQTTX CLI' --retain true -h 'localhost' -p 1883同じブローカーに対して別の新しいクライアント接続要求を開始します。新しいクライアントでトピック
t/1にサブスクライブすると、リテインドメッセージを受信します。新しいクライアントを継続的に作成してトピック
t/1にサブスクライブさせると、作成したすべての新しいクライアントがリテインドメッセージを受信します。bash$ mqttx sub -t 't/1' -h 'localhost' -p 1883 -v topic: t/1 payload: A retained message from MQTTX CLI retain: trueリテインドメッセージをクリアするには、空のメッセージをパブリッシュします:
bashmqttx pub -t 't/1' -m '' --retain true -h 'localhost' -p 1883新しいクライアント接続を開始し、トピック
t/1にサブスクライブします。リテインドメッセージが受信されないことを確認し、リテインドメッセージがクリアされたことを示します。
ダッシュボードでリテインドメッセージを確認する
リテインドメッセージをパブリッシュすると、EMQX はこのメッセージをシステム内に保存します。リテインドメッセージの一覧ページでこのメッセージを確認できます。このリテインドメッセージのトピックにサブスクライブすると、EMQX はこのメッセージをトピックにパブリッシュし、即座に受信できます。
リテインドメッセージのデフォルトの有効期限は無期限であり、手動で削除しない限り失効しません。
リテインドメッセージ一覧
Monitoring -> Retained Messages ページでは、システム内のすべてのリテインドメッセージをトピック、QoS、パブリッシュ時間、クライアントIDとともに確認できます。検索ボックスで検索によるフィルタリングが可能で、トピックのワイルドカードもサポートしています。
このページでは、リテインドメッセージのペイロードを表示する Show Payload ボタンや、削除する Delete ボタンが用意されています。Refresh ボタンで一覧を更新でき、Settings ボタンからリテインドメッセージの設定ページにアクセスできます。
デフォルトで以下の3種類のリテインドメッセージを システムトピック から確認できます:
- $SYS/brokers/+/sysdescr: 現在の EMQX ノードのシステム説明
- $SYS/brokers/+/version: 現在の EMQX ノードのバージョン番号
- $SYS/brokers: 現在の EMQX のすべてのノードの数と名前

リテインドメッセージの削除
EMQX でリテインドメッセージを削除するには、クライアントからリテインドメッセージのトピックに空のメッセージをパブリッシュするか、EMQX ダッシュボードを使用します。ダッシュボードでは、特定のリテインドメッセージに対して Delete ボタンをクリックして削除できます。また、Clear All ボタンを使ってクラスター内のすべてのリテインドメッセージを削除することも可能です。さらに、リテインドメッセージの有効期限を設定することもでき、期限切れになると EMQX が自動的に削除します。