Skip to content

MQTT リテインドメッセージ

EMQX は MQTT のリテインドメッセージ機能を実装しています。特定のトピックでパブリッシュされたメッセージを Retained としてフラグを立て、EMQX 上に永続的なメッセージとして保存できます。新しいサブスクライバーがリテインドメッセージのトピックにサブスクライブすると、そのメッセージがすでにパブリッシュされていても即座に受信します。

クライアントツールを使って EMQX に接続し、このメッセージングサービスを試すことができます。本節では、MQTTX DesktopMQTTX CLI を使ってクライアントをシミュレートし、リテインドメッセージのパブリッシュと受信の動作を確認する方法を紹介します。

前提条件

MQTTX Desktop でリテインドメッセージをパブリッシュする

  1. EMQX と MQTTX Desktop を起動します。New Connection をクリックして、パブリッシャーとしてクライアント接続を作成します。

    • Name フィールドに Demo と入力します。
    • Host にローカルホストの 127.0.0.1 を入力します(このデモの例として使用)。
    • 他の設定はデフォルトのままにして、Connect をクリックします。

    TIP

    MQTT 接続の作成に関する詳細な手順は MQTTX Desktop を参照してください。

    新しい接続の設定
  2. 接続が成功したら、テキストボックスにトピック名 sensor/t1 を入力し、スクリーンショットのようにメッセージペイロードを作成します。送信ボタンをクリックしてください。トピック sensor/t1 へのメッセージがメッセージダイアログに表示されます。

    メッセージのパブリッシュ1
  3. トピック sensor/t2 でリテインドメッセージを2つパブリッシュします。

    • 1つ目のメッセージに 1 と入力し、Retain を選択して送信ボタンをクリックします。
    • 2つ目のメッセージに 2 と入力し、送信ボタンをクリックします。
    メッセージのパブリッシュ2
  4. Connections ペインで + -> New Connection をクリックし、メッセージを受信するクライアントとしてサブスクライバー Subscriber を作成します。

  5. + New Subscription をクリックし、トピック sensor/+ にサブスクライブします。Confirm ボタンをクリックしてください。

    TIP

    トピックを sensor/+ に設定すると、sensor/t1sensor/t2 の両方にサブスクライブされます。トピックとワイルドカードの詳細は Understanding MQTT Topics & Wildcards by Case をご覧ください。

    クライアント Subscriber は、トピック sensor/t1 の最初のメッセージや、トピック sensor/t2 の最初のリテインドメッセージは受信せず、各トピックの最新のリテインドメッセージのみを受信します。これは EMQX が各トピックの最新のリテインドメッセージのみを保存しているためです。

    リテインドメッセージの受信

これで MQTTX クライアントを使ってリテインドメッセージを送信する方法を試しました。EMQX ダッシュボードから保存されている最新のリテインドメッセージを確認することもできます。詳細は ダッシュボードでリテインドメッセージを確認する をご覧ください。

MQTTX CLI でリテインドメッセージをパブリッシュする

  1. 1つのクライアントで接続要求を開始します。

  2. 次のコマンドを使ってリテインドメッセージをパブリッシュします。トピックは t/1、ペイロードは A retained message from MQTTX CLIretain = true に設定します:

    bash
    mqttx pub -t 't/1' -m 'A retained message from MQTTX CLI' --retain true -h 'localhost' -p 1883
  3. 同じブローカーに対して別の新しいクライアント接続要求を開始します。新しいクライアントでトピック 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
  4. リテインドメッセージをクリアするには、空のメッセージをパブリッシュします:

    bash
    mqttx pub -t 't/1' -m '' --retain true -h 'localhost' -p 1883
  5. 新しいクライアント接続を開始し、トピック 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 が自動的に削除します。