MQTTのロゴ | |
ステータス | 公開済み |
---|---|
開始年 | 1999 |
最新版 |
5.0[1] 2019年3月7日 |
組織 | OASIS |
委員会 | OASIS Message Queuing Telemetry Transport Technical Committee[2] |
編集者 | Andrew Banks(IBM)、Ed Briggs(Microsoft)、Ken Borgendale(IBM)、Rahul Gupta(IBM)[1] |
関連する標準 | MQTT-SN[3] |
ウェブサイト |
mqtt |
MQTT(旧称:MQ Telemetry Transport、Message Queuing Telemetry Transport)は、メッセージ指向ミドルウェアのアプリケーション層で使用される、TCP/IPによるPub/Sub型データ配信モデルの軽量なデータ配信プロトコルである。
MQTTのMQは、歴史的にはMQSeriesから来ているが、メッセージキューの機能は持たない。
非力なデバイスやネットワークが不安定な場所でも動作しやすいように、メッセージ通信電文が軽量に設計されていることが特徴である。
Pub/Sub型メッセージング·パターンには、メッセージブローカーが必要である。
ブローカーは、メッセージのTopicに基づいて、それを必要としているクライアントにメッセージを配信する。
アンディー・スタンフォード・クラークとシーラスリンクソリューションのアーレンニッパーは1999年に、プロトコルの最初のバージョンを執筆している。
仕様はロイヤリティフリーで公開されていて、現在の仕様は5となっている。[4]
MQTTには、次のような特徴がある。
プロトコル電文仕様は、軽量でシンプルになっている。
配布先条件が/
区切りの階層構造になっており、さらにワイルドカードによる指定ができる。配布先はそのパターンにマッチした宛先になる。
アプリケーションの特性に合わせて三種類の QoS (Quality of Service) レベルの指定ができる。
メッセージ再配布機能 (Durable subscribe) は、次のフローで処理される。
MQTTをサポートするブローカー(MQサーバ)は数多くある。それぞれのサーバがサポートする機能には、基本機能の他、サーバ特有の機能がある[5]。
主なMQTTブローカーには以下のようなものがある。
サーバーとの接続が確立されるのを待機し、ノード間でリンクを作る。
MQTTクライアントが必要な処理を完了し、TCP/IPセッションが切断されるのを待機する。
リクエストをMQTTクライアントに渡した後、アプリケーションスレッドに即座に戻る。
FacebookのメッセンジャーにMQTTを使用している。
IECCシグナリング制御システムのDeltaRailの最新バージョンでは、システムとシグナリングシステムの他の構成要素のさまざまな部分内の通信のためのMQTTを使用している。