EMQ X Broker詳解

一、EMQ X Broker簡介

EMQ X Broker是一個開源的分散式物聯網(MQTT)消息伺服器,它支持千萬級別的並發客戶端連接。EMQ X Broker是純 Erlang/OTP 實現的,具有高度可伸縮性,並提供Webhooks、MQTT協議處理、WebSocket支持等多種功能。以下是EMQ X Broker的一些最重要的功能。

1.支持重連

MQTT客戶端和伺服器之間的連接可能會斷開。EMQ X Broker支持MQTT客戶端的自動重連。這使得EMQ X Broker得以在網路不穩定的環境下,通過自動重新連接的方式,確保消息發送和接收的可靠性。

2.支持QoS

EMQ X Broker支持MQTT的三種服務質量(QoS):至多一次(At most once)、至少一次(At least once)和剛好一次(Exactly once)。此外,EMQ X Broker還支持多會話,MQTT客戶端可以擁有多個並發傳輸流,支持保留消息。

3.支持WebSocket

EMQ X Broker支持WebSocket,可以輕鬆地通過Web瀏覽器連接到EMQ X Broker。這使得在Web瀏覽器上實現即時通訊(IoT)應用程序成為可能。

二、EMQ X Broker安裝和使用

1.安裝EMQ X Broker

1.1 在Linux系統上安裝EMQ X Broker

$ wget https://www.emqx.io/downloads/broker/v4.3.7/emqx-ubuntu20.04-v4.3.7.zip
$ unzip emqx-ubuntu20.04-v4.3.7.zip && cd emqx
$ ./bin/emqx start

1.2 在Docker上安裝EMQ X Broker

$ docker run -d --name emqx -p 1883:1883 -p 8081:8081 emqx/emqx:latest

2.使用EMQ X Broker

2.1 使用EMQ X Dashboard管理EMQ X Broker

EMQ X Dashboard是EMQ X Broker的Web管理頁面。可以通過以下URL訪問:

http://localhost:18083

2.2 使用EMQ X Broker API

EMQ X Broker提供了REST API,通過以下方式可以調用API:

$ curl -X POST -d '{"action":"subscribe", "topic":"test"}' "http://localhost:8080/api/v4/mqtt"
$ curl -X POST -d '{"action":"publish", "topic":"test", "payload":"hello world"}' "http://localhost:8080/api/v4/mqtt"

三、EMQ X Broker配置和擴展

1.EMQ X Broker配置

EMQ X Broker的配置文件在etc目錄下。以下是一些常用配置參數的解釋:

1.1 listeners.tcp.default 應用的默認TCP監聽器配置

1.2 mqtt.message.max_size 消息最大大小

1.3 plugins.emqx_auth_username 基於用戶名和密碼的授權插件

2.EMQ X Broker擴展

EMQ X Broker提供了鉤子機制,可以在消息傳輸前或傳輸後做一些處理。

-module(hook_publisher).
-export([message_publish/3]).

message_publish(ClientId, Message, Packet) ->
  io:format("Hooked message from ~p: ~p~n", [ClientId, Message]),
  ok.

將模塊 hook_publisher 載入到 EMQ X Broker 中:

hooks.publisher = hook_publisher

四、EMQ X Broker高可用性

在分散式系統中,為了確保可靠性和高可用性,需要將EMQ X Broker配置為Master和Slave的方式運行。

以下是一些常用的EMQ X Broker高可用性配置參數:

1.EMQ X配置文件中添加HA配置

config.emqx.enterprise = true
config.emqx.enterprise.mode = slave
config.emqx.manager.enable = true
config.emqx.manager.slave_api_port = 5362

2.EMQ X Broker啟動

開始啟動主伺服器,使用以下命令啟動:

.
./bin/emqx start

啟動後,使用主伺服器管理員的憑據登錄至EMQ X Dashboard。

使用以下命令啟動從伺服器:

./bin/emqx_ctl start_slave

五、EMQ X Broker監控

EMQ X Broker提供了EMQ X Management插件,這個插件提供了一個RESTful管理介面,使得可以使用命令行或Web界面對EMQ X Broker進行監控和管理。

可以通過以下URL訪問EMQ X Management插件的Web界面:

http://localhost:18083/api-docs/management.html

六、EMQ X Broker的性能測試

EMQ X Broker具有優秀的性能和可伸縮性,可以支持千萬級別的並發客戶端連接。

可以使用EMQ X Broker提供的MQTT Load Generator(mqtt-load)工具進行性能測試。

1.安裝MQTT Load Generator(mqtt-load)工具

可以通過以下方式進行安裝:

$ sudo apt-get install python3-pip
$ sudo pip3 install mqtt-load

2.基本使用方法

以下是一些常用的MQTT Load Generator參數:

2.1 -h: MQTT Broker hostname

2.2 -t: MQTT topic name (default: mqtt-bench), -T: topic count

2.3 -u: MQTT username, -P: MQTT password

2.4 -c: MQTT client count, -n: message count per client

例如,使用以下命令運行性能測試:

$ mqtt-load -h localhost -p 1883 -t test -m publish -c 1000 -n 10000 -q 1 -F 10 --no-random --fix-payload

七、EMQ X Broker的應用場景

EMQ X Broker可以應用於各種物聯網場景,包括:

1.智能家居:EMQ X Broker可以在智能家居環境中提供可靠的通信服務。

2.工業自動化:EMQ X Broker可以在工業自動化場景中支持實時監控和控制。

3.智能農業:EMQ X Broker可以在智能農業場景中提供可靠的數據傳輸服務。

4.智慧城市:EMQ X Broker可以在智慧城市場景中支持物聯網設備的數據傳輸和處理。

結論

本文闡述了EMQ X Broker的功能、安裝和使用、配置和擴展、高可用性、監控、性能測試以及應用場景。EMQ X Broker是一個穩定、可靠、高效的MQTT消息伺服器,可以應用於各種物聯網場景,並且具有廣泛的可擴展性和可定製性。

原創文章,作者:JZBXF,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/366299.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
JZBXF的頭像JZBXF
上一篇 2025-04-02 01:02
下一篇 2025-04-02 01:28

相關推薦

  • Linux sync詳解

    一、sync概述 sync是Linux中一個非常重要的命令,它可以將文件系統緩存中的內容,強制寫入磁碟中。在執行sync之前,所有的文件系統更新將不會立即寫入磁碟,而是先緩存在內存…

    編程 2025-04-25
  • 神經網路代碼詳解

    神經網路作為一種人工智慧技術,被廣泛應用於語音識別、圖像識別、自然語言處理等領域。而神經網路的模型編寫,離不開代碼。本文將從多個方面詳細闡述神經網路模型編寫的代碼技術。 一、神經網…

    編程 2025-04-25
  • Linux修改文件名命令詳解

    在Linux系統中,修改文件名是一個很常見的操作。Linux提供了多種方式來修改文件名,這篇文章將介紹Linux修改文件名的詳細操作。 一、mv命令 mv命令是Linux下的常用命…

    編程 2025-04-25
  • Python輸入輸出詳解

    一、文件讀寫 Python中文件的讀寫操作是必不可少的基本技能之一。讀寫文件分別使用open()函數中的’r’和’w’參數,讀取文件…

    編程 2025-04-25
  • nginx與apache應用開發詳解

    一、概述 nginx和apache都是常見的web伺服器。nginx是一個高性能的反向代理web伺服器,將負載均衡和緩存集成在了一起,可以動靜分離。apache是一個可擴展的web…

    編程 2025-04-25
  • MPU6050工作原理詳解

    一、什麼是MPU6050 MPU6050是一種六軸慣性感測器,能夠同時測量加速度和角速度。它由三個感測器組成:一個三軸加速度計和一個三軸陀螺儀。這個組合提供了非常精細的姿態解算,其…

    編程 2025-04-25
  • 詳解eclipse設置

    一、安裝與基礎設置 1、下載eclipse並進行安裝。 2、打開eclipse,選擇對應的工作空間路徑。 File -> Switch Workspace -> [選擇…

    編程 2025-04-25
  • Python安裝OS庫詳解

    一、OS簡介 OS庫是Python標準庫的一部分,它提供了跨平台的操作系統功能,使得Python可以進行文件操作、進程管理、環境變數讀取等系統級操作。 OS庫中包含了大量的文件和目…

    編程 2025-04-25
  • Java BigDecimal 精度詳解

    一、基礎概念 Java BigDecimal 是一個用於高精度計算的類。普通的 double 或 float 類型只能精確表示有限的數字,而對於需要高精度計算的場景,BigDeci…

    編程 2025-04-25
  • git config user.name的詳解

    一、為什麼要使用git config user.name? git是一個非常流行的分散式版本控制系統,很多程序員都會用到它。在使用git commit提交代碼時,需要記錄commi…

    編程 2025-04-25

發表回復

登錄後才能評論