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

    你可能感兴趣的文章
    Mysql8.0注意url变更写法
    查看>>
    Mysql8.0的特性
    查看>>
    MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
    查看>>
    MySQL8修改密码的方法
    查看>>
    Mysql8在Centos上安装后忘记root密码如何重新设置
    查看>>
    Mysql8在Windows上离线安装时忘记root密码
    查看>>
    MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
    查看>>
    mysql8的安装与卸载
    查看>>
    MySQL8,体验不一样的安装方式!
    查看>>
    MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
    查看>>
    Mysql: 对换(替换)两条记录的同一个字段值
    查看>>
    mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
    查看>>
    MYSQL:基础——3N范式的表结构设计
    查看>>
    MYSQL:基础——触发器
    查看>>
    Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
    查看>>
    mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
    查看>>
    mysqldump 参数--lock-tables浅析
    查看>>
    mysqldump 导出中文乱码
    查看>>
    mysqldump 导出数据库中每张表的前n条
    查看>>
    mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
    查看>>