博客
关于我
MQTT 控制报文 - CONNECT连接服务器报文,CONNACK,DISCONNECT - 第3章
阅读量:352 次
发布时间:2019-03-04

本文共 1280 字,大约阅读时间需要 4 分钟。

MQTT CONNECT报文与CONNACK响应详解

MQTT协议中,CONNECT报文用于客户端向服务端建立网络连接,CONNACK报文则是服务端的连接响应。本文将详细介绍这两种报文的格式、功能及其应用场景。

CONNECT报文

1. CONNECT报文帧格式

CONNECT报文的帧格式由固定报头和可变报头组成。固定报头包含协议类型和保留位,剩余长度字段用于指示可变报头的长度。可变报头包括协议名、协议级别、连接标志、保持连接时间等字段。

  • 固定报头

    • 协议类型+保留位:1字节,值为0x10,表示CONNECT报文类型。
    • 剩余长度:1~4字节,取决于可变报头和有效载荷的长度。
  • 可变报头

    • 协议名:6字节,固定为MQTT,表示协议名称。
    • 协议级别:1字节,用于指定协议的修订版本。MQTT 3.1.1协议的值为0x04
    • 连接标志:1字节,控制用户名、密码、遗嘱保留、遗嘱QoS、遗嘱标志等字段的存在。
    • 保持连接时间:2字节,以秒为单位表示网络连接的最大空闲时间。

2. CONNECT固定报头

  • 协议类型0x10,表示CONNECT报文类型。
  • 保留位0x00
  • 剩余长度0x04,表示可变报头长度为4字节。

3. CONNECT可变报头

  • 用户名标志位0,表示用户名字段不存在。
  • 密码标志位0,表示密码字段不存在。
  • 遗嘱保留标志位0,表示遗嘱消息不需要保留。
  • 遗嘱QoS0x00,表示遗嘱消息的QoS等级为0。
  • 遗嘱标志位0,表示不需要发布遗嘱消息。

CONNACK报文

1. CONNACK报文帧格式

CONNACK报文由固定报头和可变报头组成,包含连接确认标志、连接返回码等字段。

  • 固定报头

    • 协议类型+保留位:1字节,值为0x02,表示CONNACK报文类型。
    • 剩余长度:1字节,值为0x02,表示可变报头长度为2字节。
  • 可变报头

    • 连接确认标志:1字节,0x00表示连接已确认。
    • 连接返回码:1字节,表示服务端对CONNECT报文的响应状态码。

2. CONNACK固定报头

  • 协议类型0x02,表示CONNACK报文类型。
  • 保留位0x00
  • 剩余长度0x02,表示可变报头长度为2字节。

3. CONNACK可变报头

  • 当前会话标志位0,表示当前会话已存在。
  • 连接返回码0x00,表示连接已成功建立。

连接过程

  • 客户端发送CONNECT报文,服务端返回CONNACK报文。
  • 如果服务端未响应或响应码不为0x00,客户端应关闭连接。
  • 客户端可发送PINGREQ报文,服务端返回PINGRESP报文以维持连接。
  • 实际案例

    • 用户名密码验证:服务端验证客户端的用户名和密码,若验证失败返回返回码0x04
    • 协议版本不支持:若服务端不支持客户端指定的协议版本,返回返回码0x01

    注意事项

    • 连接标志位:常见组合为0xC2,表示用户名标志位和密码标志位均为0
    • 保持连接时间:实际值由应用程序设定,最大值为18小时12分15秒

    通过以上详细说明,可以全面理解MQTT协议中CONNECT报文和CONNACK报文的工作原理及其应用场景。

    转载地址:http://oiqe.baihongyu.com/

    你可能感兴趣的文章
    nginx负载均衡的5种策略(转载)
    查看>>
    nginx负载均衡的五种算法
    查看>>
    Nginx运维与实战(二)-Https配置
    查看>>
    Nginx配置ssl实现https
    查看>>
    Nginx配置TCP代理指南
    查看>>
    Nginx配置——不记录指定文件类型日志
    查看>>
    Nginx配置代理解决本地html进行ajax请求接口跨域问题
    查看>>
    Nginx配置参数中文说明
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置如何一键生成
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    NHibernate学习[1]
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>