博客
关于我
一文读懂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/

    你可能感兴趣的文章
    MySQL 中锁的面试题总结
    查看>>
    MySQL 中随机抽样:order by rand limit 的替代方案
    查看>>
    MySQL 为什么需要两阶段提交?
    查看>>
    mysql 为某个字段的值加前缀、去掉前缀
    查看>>
    mysql 主从
    查看>>
    mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
    查看>>
    mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
    查看>>
    mysql 主从关系切换
    查看>>
    MYSQL 主从同步文档的大坑
    查看>>
    mysql 主键重复则覆盖_数据库主键不能重复
    查看>>
    Mysql 事务知识点与优化建议
    查看>>
    Mysql 优化 or
    查看>>
    mysql 优化器 key_mysql – 选择*和查询优化器
    查看>>
    MySQL 优化:Explain 执行计划详解
    查看>>
    Mysql 会导致锁表的语法
    查看>>
    mysql 使用sql文件恢复数据库
    查看>>
    mysql 修改默认字符集为utf8
    查看>>
    Mysql 共享锁
    查看>>
    MySQL 内核深度优化
    查看>>
    mysql 内连接、自然连接、外连接的区别
    查看>>