您好,登錄后才能下訂單哦!
MQTT 5.0 協議對部分 QoS 報文,以及報文處理的流程做了一些升級,本文對此這部分升級的內容做簡單的介紹。
在 MQTT 協議中,消息分為 3 個等級,分別用 QoS0, QoS1, QoS2, 這三個不同的 QoS 值所代表的是不同的服務質量等級。以下是每一個服務質量級別的具體描述:
0 : 最多一次發送(若消息等級為 QoS 0,發布者在發布消息時只會發送一次,不管消息是否送達);
1 : 至少一次消息發送(若消息等級為 QoS 1,發布者在發布消息時會重復發送以確保消息發送成功);
2 : 消息只發送一次,并保證送達。(若消息等級為 QoS 2, 發布者在發布消息時確保接收者只接收到一個消息并且消息不會重復)。
在三種 QoS 消息等級中,QoS 0 是最節省計算資源的, 而 QoS 1 在發布完消息后還需要去接收到一個發布確認報文來停止重復的報文發送, QoS 2 消息的傳輸則需要更多的步驟,它需要 4 次報文發送來確保消息是單次送達的,是所有消息類型中最費計算資源和帶寬的。
以下是 3 種不同 QoS 值的處理流程圖:
在 MQTT 3.0 中,QoS 0 的消息發布流程是這樣
若接收者沒有接收到 QoS1 消息或者接收到的 QoS 1 消息有問題,是不會去發送 PUBACK 確認報文的,因此發送者不會丟棄 QoS1 消息,它還會再發送
這個消息,所以 QoS1 消息是有可能被重復發布的。
為了保證消息單次發送且能送達。首先它要發布一個 PUBLISH 報文,然后接收者在接收完成時并不會返回確認報文,它會存儲接收到的消息,然后返回 PUBREC 報文給發送者,發送者在接收到 PUBREC 報文后, 將存儲的 PUBLISH 報文替換成收到的 PUBREC 報文,然后發送 PUBREL 報文給接收者。 接收者收到 PUBREL 消息后丟棄之前存儲的狀態,此時消息已經到達接收者,并且能夠確保只到達了一次。
MQTT 協議面對的是計算能力低下的嵌入式設備,雖然 MQTT 5.0 協議中對 QoS2 消息的處理流程做了一些輕微的優化,然而使用用 QoS2 消息通信仍然是非常耗資源的操作,所以通常情況下,如果對于消息傳輸的優先級要示不是特別高的話,請盡量不要傳送 QoS 2 消息。
MQTT 5.0 在 QoS 上的升級主要體現在 QoS2 的接收者在處理報文的時候一點變化,
EMQ X 發布的最新版本 3.0 已經包含了對 MQTT 5.0 協議的支持,歡迎讀者試用。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。