MQTT 发布、订阅和取消订阅 - MQTT Essentials:第 4 部分

欢迎来到 MQTT 要点的第四部分。在这篇文章中,我们将重点介绍 MQTT 中的发布、订阅和取消订阅。在本系列的前面,我们介绍了发布/订阅模型的基础知识。在这篇文章中,我们深入探讨了 MQTT 协议中发布/订阅的细节。

一、Publish

MQTT 客户端可以在连接到代理后立即发布消息。 MQTT 在代理上利用基于主题的消息过滤(详见第 2 部分)。每条消息都必须包含一个主题,代理可以使用该主题将消息转发给感兴趣的客户端。通常,每条消息都有一个有效载荷,其中包含要以字节格式传输的数据。 MQTT 与数据无关。客户端的用例决定了有效负载的结构。发送客户端(发布者)决定是否要发送二进制数据、文本数据,甚至是成熟的 XML 或 JSON。

MQTT 中的 PUBLISH 消息有几个我们要详细讨论的属性:

MQTT Publish attributes

TopicName  主体名称 主题名称是一个简单的字符串,它以正斜杠作为分隔符进行分层结构。例如,“myhome/livingroom/temperature”或“Germany/Munich/Octoberfest/people”

QoS 此数字表示消息的服务质量级别 (QoS)。共有三个级别:0、1 和 2。服务级别决定了消息对于到达预期接收者(客户端或代理)的保证类型。

RetainFlag 此标志定义消息是否由代理保存为指定主题的最后一个已知良好值。当新客户端订阅某个主题时,他们会收到保留在该主题上的最后一条消息。

Payload 这是消息的实际内容。 MQTT 与数据无关。可以发送任何编码的图像、文本、加密数据以及几乎所有二进制数据。

Packet Identifier 当消息在客户端和代理之间流动时,数据包标识符唯一地标识一条消息。数据包标识符仅与大于零的 QoS 级别相关。客户端库和/或代理负责设置此内部 MQTT 标识符。

DUP flag  该标志表明该消息是重复的,并且由于预期的接收者(客户端或代理)没有确认原始消息而被重新发送。这仅与大于 0 的 QoS 相关。通常,重新发送/复制机制由 MQTT 客户端库或代理作为实现细节处理。

当客户端向 MQTT 代理发送消息以进行发布时,代理读取消息、确认消息(根据 QoS 级别)并处理消息。代理的处理包括确定哪些客户端已订阅该主题并将消息发送给他们。

MQTT Publish Message Flow

最初发布消息的客户端只关心将 PUBLISH 消息传递给代理。代理收到 PUBLISH 消息后,有责任将消息传递给所有订阅者。发布客户端不会收到任何关于是否有人对发布的消息感兴趣或有多少客户端从代理收到消息的反馈。

二、Subscribe(订阅)

如果没有人收到消息,那么发布消息就没有意义。换句话说,如果没有客户端订阅消息的主题。要接收有关感兴趣主题的消息,客户端会向 MQTT 代理发送一条 SUBSCRIBE 消息。这个订阅消息非常简单,它包含一个唯一的数据包标识符和一个订阅列表。

MQTT Subscribe attributes

Packet Identifier 当消息在客户端和代理之间流动时,数据包标识符唯一地标识一条消息。客户端库和/或代理负责设置此内部 MQTT 标识符。

List of Subscriptions 一个 SUBSCRIBE 消息可以包含一个客户端的多个订阅。每个订阅都由一个主题和一个 QoS 级别组成。订阅消息中的主题可以包含通配符,使订阅主题模式而不是特定主题成为可能。如果一个客户端有重叠订阅,则代理会传递该主题的具有最高 QoS 级别的消息。

三、Suback

为了确认每个订阅,代理向客户端发送一个 SUBACK 确认消息。此消息包含原始订阅消息的数据包标识符(以清楚地识别消息)和返回代码列表。

MQTT SUBACK attributes

Packet Identifier 数据包标识符是用于标识消息的唯一标识符。它与 SUBSCRIBE 消息中的相同。

Return Code 代理为它在 SUBSCRIBE 消息中收到的每个主题/QoS 对发送一个返回代码。例如,如果 SUBSCRIBE 消息有五个订阅,则 SUBACK 消息包含五个返回码。返回代码确认每个主题并显示代理授予的 QoS 级别。如果代理拒绝订阅,则 SUBACK 消息包含该特定主题的失败返回代码。例如,如果客户端没有足够的权限订阅主题或主题格式错误。

 

Return Code Return Code Response
0 Success - Maximum QoS 0
1 Success - Maximum QoS 1
2 Success - Maximum QoS 2
128 Failure

 MQTT Subscribe Flow

客户端成功发送 SUBSCRIBE 消息并收到 SUBACK 消息后,它会获取与 SUBSCRIBE 消息包含的订阅中的主题匹配的每条已发布消息。

四、Unsubscribe

SUBSCRIBE 消息的对应物是 UNSUBSCRIBE 消息。此消息删除代理上客户端的现有订阅。 UNSUBSCRIBE 消息与 SUBSCRIBE 消息类似,具有包标识符和主题列表。

MQTT Unsubscribe attributes

Packet Identifier 当消息在客户端和代理之间流动时,数据包标识符唯一地标识一条消息。客户端库和/或代理负责设置此内部 MQTT 标识符。

List of Topic 主题列表可以包含客户端想要取消订阅的多个主题。只需发送主题(无 QoS)。无论最初订阅的 QoS 级别如何,代理都会取消订阅该主题。

五、Unsuback

为了确认取消订阅,代理向客户端发送一个 UNSUBACK 确认消息。此消息仅包含原始 UNSUBSCRIBE 消息的数据包标识符(以清楚地识别消息)。

MQTT UNSUBACK attributes

Packet Identifier 包标识符唯一地标识消息。如前所述,这与 UNSUBSCRIBE 消息中的数据包标识符相同。

Unsubscribe Flow

客户端收到代理的 UNSUBACK 后,可以假设 UNSUBSCRIBE 消息中的订阅被删除。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章