背景

有关博文:通信报文的构成

上一讲说到可变头与消息体要结合不同的报文类型才能够进行分析(实际上,官方的文档的介绍顺序就是这样的)

那么,我们就来具体看看有关的报文类型。

在此之前

我们捋一捋完整的通信流程,以及在这个过程中有关的报文。

客户端到服务端的网络连接建立后,客户端发送给服务端的第一个报文必须CONNECT, 连接服务端报文。

服务端发送CONNACK, 确认连接请求报文响应从客户端收到的CONNECT报文。服务端发送给客户端的第一个报文必须CONNACK

PUBLISH,发布消息报文是指从客户端向服务端或者服务端向客户端传输一个应用消息。

  • 在 QoS 0 等级,没有报文 响应。
  • 在 QoS 1 等级,PUBACK, 发布确认报文是对QoS 1等级的PUBLISH报文的响应。
  • 在 QoS 2 等级,情况稍微不同:
    • PUBREC, 发布收到报文是对QoS 2等级的PUBLISH报文的响应。它是QoS 2等级协议交换的第二个报文。
    • PUBREL, 发布释放报文是对PUBREC报文的响应。它是QoS 2等级协议交换的第三个报文。
    • PUBCOMP, 发布完成报文是对PUBREL报文的响应。它是QoS 2等级协议交换的第四个也是最后一个报文。

显然,在QoS 2 等级中,第一个报文是 PUBLISH

客户端向服务端发送SUBSCRIBE, 订阅主题报文用于创建一个或多个订阅。为了将应用消息转发给与那些订阅匹配的主题,服务端发送PUBLISH报文给客户端。SUBSCRIBE报文也(为每个订阅)指定了最大的QoS等级,服务端根据这个发送应用消息给客户端。

服务端发送SUBACK, 订阅确认报文给客户端,用于确认它已收到并且正在处理SUBSCRIBE报文。

客户端发送UNSUBSCRIBE, 取消订阅报文给服务端,用于取消订阅主题。

服务端发送UNSUBACK, 取消订阅确认报文给客户端用于确认收到UNSUBSCRIBE报文。

客户端发送PINGREQ, 心跳请求报文给服务端的。用于确认通信对方没有断开连接。

服务端发送PINGRESP, 心跳响应报文响应客户端的PINGREQ报文。表示服务端还活着。

DISCONNECT, 断开连接报文是客户端发给服务端的最后一个控制报文。表示客户端正常断开连接。

报文的简单流程图

注意,这个流程图中关于 Qos 的时序描述细节上不够。我们会在下一章专门讲解Qos这一块的要点。

%% 时序图
sequenceDiagram
participant 发布者
participant 服务器
participant 订阅者

Note right of 发布者: 发布者主动连接->

发布者 ->> + 服务器: CONNECT
服务器 -->> - 发布者: CONNACK

Note left of 订阅者: <-订阅者主动连接
订阅者 ->> + 服务器: CONNECT
服务器 -->> - 订阅者: CONNACK

par
Note right of 发布者: 心跳
发布者 ->> 服务器: PINGREQ
服务器 -->> 发布者: PINGRESP
and
订阅者 ->> 服务器: PINGREQ
服务器 -->> 订阅者: PINGRESP
end

Note right of 发布者: 发布消息(Qos 0)
发布者 ->> + 服务器: PUBLISH Qos0
Note left of 订阅者: 收到消息(Qos 0)
服务器 ->> - 订阅者: PUBLISH Qos0

Note right of 发布者: 发布消息(Qos 1)
发布者 ->> + 服务器: PUBLISH Qos1
服务器 -->> - 发布者: PUBACK Qos1

Note left of 订阅者: 接收消息(Qos 1)
服务器 ->> + 订阅者: PUBLISH Qos1
订阅者 -->> - 服务器: PUBACK Qos1

Note right of 发布者: 发布消息(Qos 2)
发布者 ->> 服务器: PUBLISH Qos2
服务器 -->> 发布者: PUBREC Qos2

发布者 ->> 服务器: PUBREL Qos2
服务器 -->> 发布者: PUBCOMP Qos2

Note right of 发布者: 接收消息(Qos 2)
服务器 ->> 订阅者 : PUBLISH Qos2
订阅者 -->> 服务器: PUBREC Qos2

服务器 ->> 订阅者: PUBREL Qos2
订阅者 -->> 服务器: PUBCOMP Qos2

par
Note right of 发布者: 断开连接
发布者 ->> 服务器: DISCONNECT
and
订阅者 ->> 服务器: DISCONNECT
end

对于报文类型以及通信的流程有了一个初步的认识以后,下一步的学习就容易很多了

MQTT 协议学习:003-MQTT通信流程介绍的更多相关文章

  1. MQTT 协议学习: 总结 与 各种定义的速查表

    背景 经过几天的学习与实操,对于MQTT(主要针对 v3.1.1版本)的学习告一段落,为了方便日后的查阅 本文链接:<MQTT 协议学习: 总结 与 各种定义的速查表> 章节整理 MQTT ...

  2. MQTT 协议学习:004-MQTT建立通信与 CONNECT 、CONNACK 报文

    背景 上一讲 MQTT 协议学习:通信报文的构成介绍了在MQTT通信中,各报文的通信流程:从本讲开始,我们开始介绍实际中使用的报文,以及它们的组成. CONNECT - 连接请求 报文 客户端到服务端 ...

  3. Tsung MQTT协议简介及MQTT xml文档配置介绍

    MQTT协议简介及MQTT xml文档配置介绍 by:授客 QQ:1033553122 1. MQTT协议介绍 MQTT(Message Queuing Telemetry Transport,消息队 ...

  4. MQTT协议学习研究 & Mosquitto简要教程(安装和使用)

    若初次接触MQTT协议,可先理解以下概念: [MQTT协议特点]——相比于RESTful架构的物联网系统,MQTT协议借助消息推送功能,可以更好地实现远程控制. [MQTT协议角色]——在RESTfu ...

  5. MQTT 协议学习:001-搭建MQTT通信环境,并抓包测试

    背景 目的:了解MQTT 通信的有关概念与流程:方便推算某些数据与文档描述是否一致. 为了能够在保证学习质量的前提下,降低配置环境的门槛,我们将服务器搭建在windwos中,实行内网间的MQTT协议访 ...

  6. MQTT 协议学习:000-有关概念入门

    背景 从本章开始,在没有特殊说明的情况下,文章中的MQTT版本均为 3.1.1. MQTT 协议是物联网中常见的协议之一,"轻量级物联网消息推送协议",MQTT同HTTP属于第七层 ...

  7. MQTT 协议学习: QoS等级 与 会话

    背景 QoS 等级 与 通信的流程有关,直接影响了整个通信.而且篇幅比较长,所以我觉得应该单独拎出来讲一下. 概念 QoS 代表了 服务质量等级. 设置上,由2 位 的二进制控制,且值不允许为 3(0 ...

  8. MQTT 协议学习:002- 通信报文的构成

    背景 之前工作中参与有关协议调试的时候,发现对于协议帧的解析是比较重要的. 参考:<MQTT协议 -- 消息报文格式>.<基于STM32实现MQTT>.<MQTT协议从服 ...

  9. MQTT 协议学习:008-在STM32上移植MQTT

    前言 通过前面了解MQTT有关概念.分析了有关的报文,我们对于这个协议也有了更深的认识.但纸上谈来终觉浅,绝知此事要躬行. 本文参考:<STM32+W5500+MQTT+Android实现远程数 ...

随机推荐

  1. 「HAOI2011」Problem c

    「HAOI2011」Problem c 传送门 由于这道题本人讲得不好,可以参考这位dalao的博客 我可就直接上代码了... 参考代码: /*---------------------------- ...

  2. Python 基础之正则之一 单字符,多字符匹配及开头结尾匹配

    一.正则表达式之单个字符匹配 格式:lst = re.findall(正则表达式,要匹配的字符串)预定义字符集 匹配内容 .匹配任意字符,除了换行符\n \d匹配数字 \D匹配非数字 \w匹配字母或数 ...

  3. javascript入门教程01

    1.javascript中变量的声明和赋值的三种方式 (1)先声明后赋值 var width; width=5; (2)同时声明和赋值变量 var width=5; var x,y,z=10; (3) ...

  4. Java基础 -4.2

    Switch分支语句 switch是一个开关语句,它主要是根据内容来进行判断的,需要注意的是switch中可以判断的只能够是数据(int.char.枚举.String)而不能够使用逻辑判断 publi ...

  5. Python学习笔记005

    if if     ==    : xxxx elif     : xxxx else: xxxx 输入字符串 input() 字符串转数值 int() 数值转字符串 str() 输出 print() ...

  6. get方法和load方法的区别

    get方法的特点    get方法采用的是立即检索策略(查询):执行到这行的时候,马上发送SQL查询    get方法查询后返回的是真实对象的本身   load方法的特点    load方法采用的是延 ...

  7. js对数字的处理:取整、四舍五入、数字与字符串的转换

    取整.四舍五入 向下取整Math.floor() 向上取整Math.ceil() 四舍五入Math.round()) 保留有效数位n.toFixed() 产生大于等于0小于1的随机数Math.rand ...

  8. CSS3-边框(border-radius、box-shadow、border-image)

    CSS3中的边框属性:border-radius.box-shadow.border-image 圆角:border-radius 使用 CSS3 border-radius 属性,你可以给任何元素制 ...

  9. 「luogu4135」作诗

    「luogu4135」作诗 传送门 分块好题. 预处理出 \(f[i][j]\) 表示 \(i\) 号块到 \(j\) 号块的答案,\(num[i][k]\) 表示 \(k\) 在前 \(i\) 块的 ...

  10. Python 基础之面向对象初识与类的封装

    一.面向对象类的初识 1.类的定义 #三种方式:#1.class MyClass:    pass #2.推荐class MyClass():    pass #3.class MyClass(obj ...