MQTT:
MQTT(Message Queuing Telemetry Transport,消息队列遥测传输)是IBM开发的一个即时通讯协议,有可能成为物联网的重要组成部分。该协议支持所有平台,几乎可以把所有联网物品和外部连接起来,被用来当做传感器和制动器(比如通过Twitter让房屋联网)的通信协议。
MQTT最大优点在于, 可以以极少的代码和有限的带宽为连接远程设备提供实时可靠的消息服务.
MQTT特性:
MQTT协议是为大量计算能力有限,且工作在低带宽、不可靠的网络的远程传感器和控制设备通讯而设计的协议,它具有以下主要的几项特性:
1、使用发布/订阅消息模式,提供一对多的消息发布,解除应用程序耦合;
2、对负载内容屏蔽的消息传输;
3、使用 TCP/IP 提供网络连接;
4、有三种消息发布服务质量:
a、(QOS0)“至多一次”,消息发布完全依赖底层 TCP/IP 网络。会发生消息丢失或重复。这一级别可用于如下情况,环境传感器数据,丢失一次读记录无所谓,因为不久后还会有第二次发送。
b、(QOS1)“至少一次”,确保消息到达,但消息重复可能会发生。
c、(QOS2)“只有一次”,确保消息到达一次。这一级别可用于如下情况,在计费系统中,消息重复或丢失会导致不正确的结果。(在实际编程中,只需要设置QoS值即可实现以上几种不同消息发布服务质量模式)
5、小型传输,开销很小(固定长度的头部是 2 字节),协议交换最小化,以降低网络流量;
6、使用 Last Will 和 Testament 特性通知有关各方客户端异常中断的机制;
3、 MQTT协议原理
3.1 协议实现方式
协议的完成需要客户端和服务器端通讯完成,MQTT协议中有三种身份:发布者,代理,订阅者。消息发布和订阅者都是客户端,消息代理是服务器。发布者和订阅者可以相同。
MQTT消息分为主题(Topic)和负载(Payload)两部分:Topic,可以理解为消息类型,订阅者订阅相应的主题就会收到该主题的消息内容。Payload,可以理解为消息内容,指订阅者具体使用的内容。
3.2 网络传输与应用消息
建立客户端到服务器的连接,提供两者之间一个有序,无损,基于字节流的双向传输。
订阅:订阅包含主题筛选器(Topic Filter)和最大服务质量(QoS)。订阅会与一个会话(Session)关联。一个会话可以包含多个订阅。每一个会话中的每个订阅都有一个不同的主题筛选器。
会话:每个客户端与服务器建立连接后就是一个会话,客户端和服务器之间有状态交互。会话存在于一个网络之间,也可能在客户端和服务器之间跨越多个连续的网络连接。
主题:连接到一个应用程序消息的标签,该标签与服务器的订阅相匹配。服务器会将消息发送给订阅所匹配标签的每个客户端。
主题筛选器:对一个主题名通配符筛选器,在订阅表达式中使用表达匹配到多少主题。
负载:订阅者具体接收内容。
3.3 MQTT协议数据包结构
一个MQTT数据包包括三个部分:固定头(Fixed header),可变头(Variable header),消息体(payload)。
固定头(Fixed Header):存在于数据包中,表示数据包类型和数据包的分组类标识。第一个字节表示消息类型和QoS标志,第二个字节开始是剩余长度字段,该长度是后面的可变报文头加上消息负载的总长度。最多四字节。最高位为1表示后面还存在字节。
固定头构造: