物聯(lián)網(wǎng)(IoT)連接協(xié)議-MQTT 物聯(lián)網(wǎng) (IoT) 設(shè)備必須連接互聯(lián)網(wǎng)。通過連接到互聯(lián)網(wǎng),設(shè)備就能相互協(xié)作,以及與后端服務(wù)協(xié)同工作;ヂ(lián)網(wǎng)的基礎(chǔ)網(wǎng)絡(luò)協(xié)議是 TCP/IP。MQTT(消息隊(duì)列遙測傳輸) 是基于 TCP/IP 協(xié)議棧而構(gòu)建的,已成為 IoT 通信的標(biāo)準(zhǔn)。 MQTT(Message Queuing Telemetry Transport,消息隊(duì)列遙測傳輸)是IBM開發(fā)的一個即時通訊協(xié)議,它是一種輕量級的、基于代理的“發(fā)布/訂閱”模式的消息傳輸協(xié)議。其具有協(xié)議簡潔、小巧、可擴(kuò)展性強(qiáng)、省流量、省電等優(yōu)點(diǎn),而且已經(jīng)有PHP,JAVA,Python,C,C#,Go等多個語言版本,基本可以使用在任何平臺上,幾乎可以把所有聯(lián)網(wǎng)物品和外部連接起來,所以特別適合用來當(dāng)做物聯(lián)網(wǎng)的通信協(xié)議。 相比HTTP協(xié)議不適合大規(guī)模的物聯(lián)網(wǎng)應(yīng)用,這是因?yàn)椋?/font>
- H% c7 V" P% O+ D1. HTTP 是一種同步協(xié)議?蛻舳诵枰却⻊(wù)器響應(yīng),依賴較高的網(wǎng)絡(luò)信號質(zhì)量。 2. HTTP 是單向的。客戶端必須發(fā)起連接。在 IoT 應(yīng)用程序中,設(shè)備或傳感器通常是客戶端,這意味著它們無法被動地接收來自網(wǎng)絡(luò)的命令。 3. HTTP 是一種 1-1 協(xié)議?蛻舳税l(fā)出請求,服務(wù)器進(jìn)行響應(yīng)。將消息傳送到網(wǎng)絡(luò)上的所有設(shè)備上,不但很困難,而且成本很高,而這是 IoT 應(yīng)用程序中的一種常見使用情況。 4. HTTP 是一種有許多標(biāo)頭和規(guī)則的重量級協(xié)議。它不適合受限的網(wǎng)絡(luò)。 MQTT特點(diǎn)MQTT協(xié)議是為大量計算能力有限,且工作在低帶寬、不可靠的網(wǎng)絡(luò)的遠(yuǎn)程傳感器和控制設(shè)備通訊而設(shè)計的協(xié)議,它具有以下主要的幾項(xiàng)特性: 1. 使用發(fā)布/訂閱消息模式,一個發(fā)布者可以對應(yīng)多個訂閱者,當(dāng)發(fā)布者發(fā)生變化的時候,他可以將消息一一通知給所有的訂閱者。這種模式提供了更大的網(wǎng)絡(luò)擴(kuò)展性和更動態(tài)的網(wǎng)絡(luò)拓?fù)。因(yàn)?/font> MQTT 消息是按主題進(jìn)行組織的,所以應(yīng)用程序開發(fā)人員能靈活地指定某些客戶端只能與某些消息交互。 根據(jù) MQTT 的基礎(chǔ)了解后并結(jié)合簡單的架構(gòu),在這里做一個簡單的示例圖,可以更直觀的理解MQTT協(xié)議的通信模型。MQTT Broker 就選擇 EMQ 作為示范。比如有1個溫度傳感器(1個Machine),1個移動設(shè)備,1個電腦,一個服務(wù)器(3個Machine),都可以得到或者顯示溫度傳感器的溫度值,需要先通過 MQTT協(xié)議subscribe(訂閱)一個比如叫 temperature 的 topic(主題)如下圖: 圖中移動設(shè)備,服務(wù)器,電腦需要先通過 EMQ subscribe 一個叫 temperature 的 topic,當(dāng)溫度傳感器 publish 溫度數(shù)據(jù),三個設(shè)備就可以收到了。 2.對負(fù)載內(nèi)容屏蔽的消息傳輸; 3.使用 TCP/IP 提供網(wǎng)絡(luò)連接; 4.有三種消息發(fā)布服務(wù)質(zhì)量: l "至多一次",消息發(fā)布完全依賴底層TCP/IP網(wǎng)絡(luò)。會發(fā)生消息丟失或重復(fù)。這一級別可用于如下情況,環(huán)境傳感器數(shù)據(jù),丟失一次讀記錄無所謂,因?yàn)椴痪煤筮會有第二次發(fā)送。這一種方式主要普通APP的推送,倘若你的智能設(shè)備在消息推送時未聯(lián)網(wǎng),推送過去沒收到,再次聯(lián)網(wǎng)也就收不到了。 l "至少一次",確保消息到達(dá),但消息重復(fù)可能會發(fā)生。這一級別可用于如下情況,你需要獲得每一條消息,并且消息重復(fù)發(fā)送對你的使用場景無影響。 l "只有一次",確保消息到達(dá)一次。在一些要求比較嚴(yán)格的計費(fèi)系統(tǒng)中,可以使用此級別。在計費(fèi)系統(tǒng)中,消息重復(fù)或丟失會導(dǎo)致不正確的結(jié)果。這種最高質(zhì)量的消息發(fā)布服務(wù)還可以用于即時通訊類的APP的推送,確保用戶收到且只會收到一次。 5.小型傳輸,開銷很小(固定長度的頭部是 2 字節(jié)),協(xié)議交換最小化,以降低網(wǎng)絡(luò)流量。它有一個用來指定消息類型的簡單標(biāo)頭,有一個基于文本的主題,還有一個任意的二進(jìn)制有效負(fù)載。應(yīng)用程序可對有效負(fù)載采用任何數(shù)據(jù)格式,比如 JSON、XML、加密二進(jìn)制或 Base64,只要目標(biāo)客戶端能夠解析該有效負(fù)載; 6.使用 Last Will 和 Testament 特性通知有關(guān)各方客戶端異常中斷的機(jī)制。奇跡物聯(lián)作為專注eSIM 技術(shù)的物聯(lián)網(wǎng)公司,發(fā)布的AM20E,AM21E,AM400E等NB/LTE模組,支持包括MQTT協(xié)議在內(nèi)的多種通信協(xié)議,客戶借助eSIM模組,可將物聯(lián)網(wǎng)終端設(shè)備部署在私有服務(wù)器上,也可在阿里云,OneNET等公有云平臺上部署,我公司提供豐富的產(chǎn)品開發(fā)資料和程序例程,幫助用戶實(shí)現(xiàn)項(xiàng)目快速落地。 · 聯(lián)系電話:楊先生18821220132 · 1 l" Q1 O Q% n( a
2 P/ D! t3 d/ j1 y, |& V 5 D" t+ ?' d9 Y
5 _- F3 v' Z: z" P
|