はじめに
MQTT(Message Queuing Telemetry Transport)は、IoT(Internet of Things)のデファクトスタンダードなメッセージングプロトコルである。IoTの発展に伴い、MQTTブローカーはIoT機器の接続や、接続された機器とクラウドサービス間のデータ移動に不可欠になっています。
EMQXとMosquittoは、最も人気のあるオープンソースのMQTTブローカーの2つです。EMQXは、拡張性の高い分散型MQTTブローカーで、クラスタリングをサポートしています。Mosquittoは、フットプリントが小さく、シングルスレッド・アーキテクチャの軽量なMQTTブローカーです。
このブログ記事では、2023年の2つのブローカーを詳細に比較します。
Mosquittoの概要
Mosquittoプロジェクトは、2009年にRoger Lightによって最初に開発され、その後Eclipse Foundationに寄贈され、Eclipse Public License(EPL/EDLライセンス)の下でライセンスされています。世界で最も広く使われているMQTTブローカーの1つとして、Mosquittoは2023年3月現在で7k以上のGitHubスターを持っています。
MosquittoはC/C++で書かれており、シングルスレッド・アーキテクチャを使用しています。MosquittoはMQTTプロトコルバージョン5.0、3.1.1、3.1を実装し、SSL/TLSとWebSocketをサポートしています。軽量設計のため、Mosquittoは組み込み機器やリソースの限られたサーバーへの導入に適しています。
長所です:
- 簡単な設定と使用方法
- MQTT 5.0プロトコル対応
- 軽量で効率的
- 積極的なコミュニティサポート
Cons: - 拡張性が低い(10万人未満)
- クラスタリングサポートなし
- エンタープライズ向け機能を欠く
- Cloud-Nativeのサポートは限定的です。
EMQXの概要
EMQXプロジェクトは2012年にGitHubで開始され、Apacheバージョン2.0の下でライセンスされています。EMQXは現在、MQTT 5.0、MQTT-SN、MQTT over QUICなどの先進機能をサポートする、世界で最もスケーラブルなMQTTメッセージングサーバーです。IoT、産業用IoT(IIoT)、車両インターネット(IoV)のビジネスクリティカルなアプリケーションで広く利用されています。
EMQXは、大規模スケーラブルなソフトリアルタイムシステムを構築するためのプログラミング言語であるErlang/OTPで書かれています。EMQXは、Mosquittoとは異なり、設立当初からマスターレス分散アーキテクチャを採用し、高可用性と水平スケーラビリティを実現しています。最新版のEMQX 5.0では、23ノードの単一クラスターで1億の同時MQTT接続を確立する規模となっています。
ご覧ください:EMQX 5.0による100M MQTT接続の達成
長所です:
- 大規模なデプロイメントに対応
- 高可用性
- 水平方向のスケーラビリティ
- 高性能・高信頼性
- 豊富なエンタープライズ機能
- MQTT over QUICの先駆け。
Cons: - 設定や構成が複雑
- 効果的なマネジメントが難しい
- ログが乱れる場合があります
コミュニティとポピュラリティ
EMQXはGitHubで最も評価が高く、最もアクティブなMQTT Brokerプロジェクトで、過去12ヶ月で11.4スター、3,000以上のコミットが行われています。
Mosquittoは、軽量なシングルスレッドアーキテクチャを持つEMQXよりも、特にリソースの限られた組込み機器での導入が進んでいるようです。
スケーラビリティとパフォーマンス
Mosquittoは軽量なMQTTブローカーとして、クラスタリングアーキテクチャをサポートしませんが、シングルノードのパフォーマンスは優れています。小さなリソースフットプリントのサーバーで、100kを超える同時MQTT接続をサポートすることができます。
EMQXは、拡張性の高い分散型MQTTメッセージングブローカーとして、単一ノードで数百万、単一クラスタで1億の同時接続をサポートできますが、CPUとメモリの使用量ははるかに高くなります。
ご覧ください:EMQX vs Mosquitto パフォーマンスベンチマークレポートをご覧ください。
MQTTとコネクティビティ
Mosiquittoは、MQTTプロトコルバージョン3.1/3.1/5.0を実装し、意志メッセージ、保持メッセージ、共有サブスクリプションなどのプロトコル仕様をサポートし、MQTT over WebSocketをサポートします。
EMQXは、MQTT 3.1/3.1/5.0とMQTT over Websocketプロトコルを完全にサポートしています。EMQX 5.0では、MQTT Over QUICの画期的なサポートも導入しています。多重化、接続確立と移行の高速化により、次世代のMQTT標準となる可能性を秘めています。
さらにEMQXは、MQTT-SN、CoAP、LwM2M、STOMPといった複数のプロトコルゲートウェイをサポートするように拡張することができます。
セキュリティ
IoTデバイスの接続や、接続されたデバイスとクラウドサービス間でやり取りされるデータには、セキュリティが重要です。MosquittoとEMQXはともに、TLS/SSLに基づくセキュアな接続をサポートしています。さらにEMQXは、QUICトランスポート、OCSPステープリング、監査ログ、Black Duckによるソースコードスキャンをサポートしています。
認証と認可
MQTTクライアントの認証やアクセス制御については、Mosiquittoが提供するダイナミックセキュリティプラグインにより、ユーザー名/パスワードによる認証やアクセス制御を柔軟に対応することができます。
EMQXには、ユーザー名-パスワード認証、JWT認証、MQTT 5.0プロトコルに基づく拡張認証など、複数の認証メカニズムに対するサポートが組み込まれています。EMQXの認証は、ファイル、Redis、MySQL、PostgreSQL、MongoDBなど、さまざまなデータバックエンドと統合されています。
また、EMQXはフラッピング検知やブロックリスト機能を備えており、DashboardやHTTP APIを介して、IPアドレス、clientId、ユーザー名をブロックリストに追加することで、特定のクライアントをブロックすることが可能です。
データインテグレーション
軽量ブローカーであるMosquittoは、データ統合をサポートしません。ユーザーは、MosquittoからMQTTメッセージを消費して、外部のデータベースやクラウドサービスに取り込むためのコードを書くことができます。
EMQXにはSQLベースのルールエンジンが組み込まれており、ブローカー内でリアルタイムにMQTTメッセージを抽出、フィルタリング、エンリッチ、変換するのに役立ちます。
EMQXのEnterprise Editionは、ルールエンジンとすぐに使えるデータブリッジを使って、Kafka、データベース、クラウドサービスとシームレスに統合することができます。
操作性・観察性
Mosquittoは、ブローカーの状態を監視し、問題のトラブルシューティングを行うための基本的なロギングとデバッグ機能を備えています。しかし、高度な管理・監視機能がないため、実行中の状態を把握し、パフォーマンスを最適化することが困難です。
EMQXは、HTTP APIとDashboardを通じて、リッチでビジュアルな監視機能を提供し、監視と管理を容易にする。また、EMQXはPrometheusやDatadogとの連携をサポートしており、O&Mチームはサードパーティの監視プラットフォームを容易に利用することができます。
クラウドネイティブとKubernetes
EMQXとMosquittoは、どちらもDockerベースのコンテナ型デプロイメントをサポートしています。EMQXはKubernetes OperatorやTerraformのサポートに優れており、パブリッククラウドプラットフォームへのデプロイや運用が容易になります。
また、EMQXは、世界中のAWS、Google Cloud、Microsoft Azureの17以上のリージョンで、Serverless、専用、BYOCのMQTTメッセージングサービスを提供しています。
EMQX Kubernetes Operator: https://github.com/emqx/emqx-operator
MosquittoからEMQXへのブリッジ接続
EMQXとMosquittoは全く異なるMQTTブローカーですが、MQTTブリッジングアプローチで完全に動作させることができます。
IoTエッジの組み込みハードウェアやゲートウェイにMosquittoを導入し、MQTTブリッジを介してクラウド上の大規模EMQXクラスタにIoTデータを集約・インジェストすることができます。
Mosquitto MQTTメッセージのEMQXへの橋渡し」を参照してください。
まとめ
上記の比較から、EMQXとMosquittoは、異なるニーズやユースケースに対応する人気のMQTTブローカーであることがわかります。
Mosquittoは、シングルスレッドで軽量なMQTT Brokerとして、IoTエッジのための組み込みハードウェア、産業用ゲートウェイ、小型サーバーへの導入に適しています。
EMQXは、高可用性と水平方向のスケーラビリティをサポートする、拡張性の高い分散型MQTTサーバーです。クラウド展開、大規模なIoT、IIoT、コネクテッドカーなどのアプリケーションにより適しています。
つまり、組み込みハードウェアやIoTエッジのデプロイメントにはMosquittoを選び、クラウドではEMQXを大規模スケーラブルで高可用性のMQTTメッセージングサービスとして利用することができます。
参考文献
- Eclipse Mosquitto
- Eclipse Mosquitto Documentation
- EMQX: The World's #1 Open Source Distributed MQTT Broker
- EMQX 5.0 Documentation
- EMQX Enterprise Documentation
- EMQX Operator Documentation
- MQTT over QUIC: Next-Generation IoT Standard Protocol
元々は www.emqx.com で公開されました