博客
关于我
一文读懂MQTT协议
阅读量:156 次
发布时间:2019-02-28

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

MQTT(Message Queuing Telemetry Transport,消息队列遥测传输协议)是一种基于发布/订阅(publish/subscribe)模式的“轻量级”通讯协议,由IBM于1999年发布,构建于TCP/IP协议上。MQTT以其高效低资源消耗的特点,在物联网、小型设备和远程设备通信中应用广泛。本文将深入分析MQTT的设计原则、特性以及数据包结构。

1. MQTT的设计原则

MQTT设计特别考虑了物联网环境的特殊需求,遵循以下原则:

  • 精简设计:去除可有可无的功能,保持协议简洁易于实现。
  • 发布/订阅模式:支持消息在传感器之间的流动,减少系统耦合。
  • 动态主题创建:允许用户自定义主题,支持零运维模式。
  • 资源节约:通过最小化传输量和头部大小,提升网络传输效率。
  • 适应性网络:考虑高延迟和不稳定网络,确保消息可靠传输。
  • 会话控制:支持连续会话管理,适合多次连接场景。
  • 低计算能力支持:设计为低功耗,适合嵌入式设备。
  • 服务质量管理:提供多级消息可靠性,满足不同场景需求。
  • 灵活性:不强制数据格式,支持任意类型消息传输。
  • 2. MQTT的主要特性

    MQTT的核心特性包括:

  • 发布/订阅模式:支持一对多的消息发布,解耦应用程序。
  • 消息中继:屏蔽负载过重的消息,优化网络流量。
  • 基于TCP/IP:利用标准网络协议,确保广泛兼容性。
  • 消息质量等级:提供三种服务质量(QoS):至多一次、至少一次和只有一次。
  • 小型传输:固定头部仅2字节,减少网络负担。
  • 遗言机制:通过Last Will和Testament机制通知离线设备。
  • 3. MQTT协议数据包结构

    MQTT数据包由固定头、可变头和消息体三部分组成:

  • 固定头(Fixed header):包含数据包类型和标识位。

    • 数据包类型:由4位字段确定,包括CONNECT、PUBLISH、SUBSCRIBE等。
    • 标识位:包含DUP、QoS、RETAIN等控制位。
  • 可变头(Variable header):根据数据包类型,包含额外信息。

    • 通常用于PUBLISH、SUBSCRIBE等有状态消息。
  • 消息体(Payload):包含实际消息内容,包括 CONNECT中的客户端信息、SUBSCRIBE的主题列表等。

  • 4. MQTT的核心组件

    MQTT系统包含以下关键组件:

    • 发布者(Publisher):发送消息到主题。
    • 代理(Broker):接收并路由消息,支持多个客户端。
    • 订阅者(Subscriber):监听特定主题的消息。
    • 会话(Session):维护客户端与代理的连接状态。

    5. MQTT消息传输流程

  • 连接建立:客户端通过TCP连接到代理。
  • 订阅主题:客户端向代理发送SUBSCRIBE消息,代理确认。
  • 发布消息:发布者向代理发布消息,代理转发给订阅者。
  • 消息质量控制:根据QoS级别确保消息可靠传输。
  • 断开连接:客户端或代理断开连接,释放资源。
  • MQTT协议通过简洁的设计和灵活的特性,成为物联网和嵌入式设备通信的首选方案。其适应性强、资源消耗低,能够在各种复杂网络环境中稳定工作。

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

    你可能感兴趣的文章
    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
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
    查看>>
    NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
    查看>>
    NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
    查看>>
    NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
    查看>>
    NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
    查看>>