内容简介:了解MQTT怎么建立连接之后,现在重点来了解MQTT怎么推送,订阅两个方面。先见一张图:
背景
了解MQTT怎么建立连接之后,现在重点来了解MQTT怎么推送,订阅两个方面。
概念
先见一张图:
这张图是依旧借鉴HiveMQ的图,来讲述MQTT协议的推送和订阅的过程。推送和订阅,我们很容易理解。这里里面的推送客户端和订阅客户端,在上篇文章 MQTT协议的初浅认识之连接建立 中也都提到过,都是属于MQTT的客户端。这里面有一个比较陌生的概念是 Topic ,即话题这个概念。
话题
这个东西在MQTT里面很灵活,客户端订阅的对象其实也就是话题。话题主要有 话题主题+正斜杠 组成。如下:
话题其实就是由 话题主题+正斜杆 ,组成的一个字符串,客户端订阅了这个话题字符串之后,就可以接收这个MQTT推送过来关于这个话题的消息。中间件也是根据话题,来分发从推送客户端推送到中间件的消息。
话题通配符
单级: +
表示不接收间隔多个话题级别,如下图:
匹配的消息结果,如下:
多级: #
表示接收多级间隔话题,如下:
匹配消息,如下:
开头: $
表示以什么开头的消息,这个不常用。
推送消息
MQTT客户端可以在连接到中间件后立即发布消息。MQTT中间件利用基于话题的消息进行过滤。每条消息必须包含一个话题,中间件可以使用该话题将消息转发给感兴趣的客户端。通常,每条消息都有包含一个的MQTT载荷与数据有关。客户端决定了有效负载的结构。发送客户端(发布者)决定是否要发送二进制数据,文本数据,甚至是完整的数据。XML或JSON。
参考说明:
- packetId:消息id
- topicName:话题标识
- qos :通讯质量级别,分为三个级别,对应着三种不同的通讯方式,这个很重要的。
- retainFlag:此标志定义中间件是否将消息保存为指定话题的最后一个默认消息值。当新客户端订阅某个话题时,他们会收到该主题上保留的最后一条消息。
- payload:载荷,业务内容就在这里。
- dupFlag:是否已经重复发送消息标识。
当客户端向MQTT中间件发送消息以进行发布时,中间件会读取该消息,确认消息(根据QoS级别)并处理该消息。中间件处理消息包括确定哪些客户已订阅该话题并将消息发送给他们。
最初发布消息的客户端只关心向中间件发送PUBLISH消息。一旦中间件收到PUBLISH消息,中间件就有责任将消息传递给所有订阅客户端。发布客户端不会获得有关是否有人对发布的消息感兴趣或有多少订阅客户端从中间件接收消息的任何反馈。
订阅消息
客户端订阅消息,相对于推送消息结构要简单的多,主要包括两个部分:
- packetId:消息id;
- qos+topic:通讯质量级别和话题数组
中间件收到客户端端的订阅SUBSCRIBE消息后,中间件会回答SUBACK消息。
SUBACK消息
参数说明:
- packetId:消息id
- returnCode:返回代码
返回代码说明:
Return Code | Return Code Response |
---|---|
0 | Success – Maximum QoS 0 |
1 | Success – Maximum QoS 1 |
2 | Success – Maximum QoS 2 |
128 | Failure |
整个订阅过程,如图:
参考
MQTT Essentials Part 5: MQTT Topics & Best Practices
MQTT Essentials Part 4: MQTT Publish, Subscribe & Unsubscribe
以上所述就是小编给大家介绍的《原 荐 MQTT协议的初浅认识之推送订阅》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 微信小程序订阅消息推送
- 设计模式之发布订阅模式(2) Redis实现发布订阅模式
- 设计模式之发布订阅模式(1) 一文搞懂发布订阅模式
- 使用并解析 OPML 格式的订阅列表来转移自己的 RSS 订阅(解析篇)
- Redis订阅与发布
- 消息队列和发布订阅
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。