美文网首页
MQTT协议之消息订阅

MQTT协议之消息订阅

作者: 技术学习 | 来源:发表于2016-08-08 16:34 被阅读2789次

    在MQTT协议中,最重要的就是发布/订阅,下面重点分析下消息订阅。

    SUBSCRIBE

    一般来讲,客户端在成功建立TCP连接之后,发送CONNECT消息,在得到服务器端授权允许建立彼此连接的CONNACK消息之后,客户端会发送SUBSCRIBE消息,订阅感兴趣的Topic主题列表(至少一个主题),一个完整示范如下:


    mqtt-subscribe

    固定头部

    Qos Level,可根据实际情况进行调整为0/1/2等。一般设为0表示最多一次。客户端可设置OoS Level值。 DUP flag,值为0表示第一次发送。

    可变头部

    因为上面示范QoS level值为1,因此需要客户端传递消息ID,16位,无符号的short类型。

    消息体

    订阅的主题名称采用修改版UTF-8编码,然后紧跟着对应的QoS值。下面的次序,可能更为形象:

    Topic name "a/b"
    Requested QoS 1
    Topic name "c/d"
    Requested QoS 2

    订阅者的Topic name支持通配符#和+ :

    1. #支持一个主题内任意级别话题
    • +只匹配一个主题级别的通配符

    eg:
    finance/stock/#
    finance/sotkc/ibm/+
    都是有效,更具体规则,请参阅协议附加部分。
    在服务器接收处理时,按照顺序读取即可:

    String topicName = readUTF();
    int qosVal = read();
    

    服务器可以发送QoS不大于客户端设置OoS的消息,尤其是服务器不提供良好的持久化机制的时候。

    SUBACK

    服务器会对发出SUBSCRIBE的消息返回一个确认消息。


    mqtt-suback

    可变头部

    Message Identifier,服务器需要附加,客户端需要处理。

    消息体

    QoS,为服务器根据实际情况授予的QoS级别列表,和客户端发送的SUBSCRIBE的订阅Topic Name顺序完全一致。

    客户端订阅几个TOPIC,服务器端一一给出各个TOPIC的QoS具体值。

    UNSUBSCRIBE

    服务器需要支持客户端取消订阅功能,UNSUBSCRIBE消息格式和SUBSCRIBE消息格式差不多,除了消息类型不同,消息体中没有了QoS字节,其它没有区别。


    mqtt-unsubscribe

      可变头部的消息ID的出现还是由固定头部的QoS Level(1)决定是否存在。
      一般来讲,客户端发布退订,服务器端需要返回退订确认。
      MQTT没讲是否允许客户端退订所有TOPIC。

    UNSUBACK

    服务器返回的UNSUBSCRIBE消息UNSUBACK相应很简单,没有消息体。


    mqtt-unsuback

    小结

    订阅部分,共有四个消息,分别一一对应。

    命令 响应 备注 建议
    SUBSCRIBE SUBACK 协议没有涉及最多运行订阅TOPIC数目,隐藏的隐患 建议至多10个
    UNSUBSCRIBE UNSUBACK 是否可以退订所有订阅,不详 建议保留至少一个Topic

    相关文章

      网友评论

          本文标题:MQTT协议之消息订阅

          本文链接:https://www.haomeiwen.com/subject/xojrsttx.html