MQTT实战之MQTT入门

MQTT入门介绍(一)

一.MQTT简述服务器

MQTTMessage Queuing Telemetry Transport,消息队列遥测传输协议),是一种基于发布/订阅(publish/subscribe)模式的"轻量级"通信协议,该协议构建于TCP/IP协议上,由IBM1999年发布。MQTT最大优势在于,能够以极少的代码和有限的带宽,为链接远程设备提供实时可靠的消息服务。做为一种低开销、低带宽占用的即时通信协议,使其在物联网、小型设备、移动应用等方面有较普遍的应用。网络

MQTT是一个基于客户端-服务器的消息发布/订阅传输协议。MQTT协议是轻量、简单、开放和易于实现的,这些特色使它适用范围很是普遍。在不少状况下,包括受限的环境中,如:机器与机器(M2M)通讯和物联网(IoT)。其在,经过卫星链路通讯传感器、偶尔拨号的医疗设备、智能家居、及一些小型化设备中已普遍使用。运维

 

 

二.设计规范ui

因为物联网的环境是很是特别的,因此MQTT遵循如下设计原则:编码

(1)精简,不添加无关紧要的功能;spa

2)发布/订阅(Pub/Sub)模式,方便消息在传感器之间传递;设计

3)容许用户动态建立主题,零运维成本;队列

4)把传输量降到最低以提升传输效率;ip

5)把低带宽、高延迟、不稳定的网络等因素考虑在内;ci

6)支持连续的会话控制;

7)理解客户端计算能力可能很低;

8)提供服务质量管理;

9)假设数据不可知,不强求传输数据的类型与格式,保持灵活性。

三.主要特性

MQTT协议工做在低带宽、不可靠的网络的远程传感器和控制设备通信而设计的协议,它具备如下主要的几项特性:

1)使用发布/订阅消息模式,提供一对多的消息发布,解除应用程序耦合。

这一点很相似于XMPP,可是MQTT的信息冗余远小于XMPP,,由于XMPP使用XML格式文原本传递数据。

2)对负载内容屏蔽的消息传输。

3)使用TCP/IP提供网络链接。

主流的MQTT是基于TCP链接进行数据推送的,可是一样有基于UDP的版本,叫作MQTT-SN。这两种版本因为基于不一样的链接方式,优缺点天然也就各有不一样了。

4)有三种消息发布服务质量:

Qos = 0; "至多一次",消息发布彻底依赖底层TCP/IP网络。会发生消息丢失或重复。这一级别可用于以下状况,环境传感器数据,丢失一次读记录无所谓,由于不久后还会有第二次发送。这一种方式主要普通APP的推送,假若你的智能设备在消息推送时未联网,推送过去没收到,再次联网也就收不到了。

Qos = 1; "至少一次",确保消息到达,但消息重复可能会发生。

Qos = 0; "只有一次",确保消息到达一次。在一些要求比较严格的计费系统中,可使用此级别。在计费系统中,消息重复或丢失会致使不正确的结果。这种最高质量的消息发布服务还能够用于即时通信类的APP的推送,确保用户收到且只会收到一次。

(5)小型传输,开销很小(固定长度的头部是2字节),协议交换最小化,以下降网络流量。

这就是为何在介绍里说它很是适合"在物联网领域,传感器与服务器的通讯,信息的收集",要知道嵌入式设备的运算能力和带宽都相对薄弱,使用这种协议来传递消息再适合不过了。

6)使用Last Will和Testament特性通知有关各方客户端异常中断的机制。

Last Will:即遗言机制,用于通知同一主题下的其余设备发送遗言的设备已经断开了链接。

Testament:遗嘱机制,功能相似于Last Will。

 

四.相关术语

(1) 网络链接(NetWork Connection

      MQTT使用的底层传输协议基础设施。

1) 客户端使用它链接服务端

2) 它提供有序的、可靠的、双向字节流传输

(2) 客户端(Client

      使用MQTT的程序或设备。客户端老是经过网络链接到服务端。它能够:

1) 发布应用消息给其余相关的客户端

2) 订阅以请求接收相关的应用消息

3) 取消订阅以移除接受应用消息的请求

4) 从服务端断开链接

(3) 服务端(Server

     一个程序或者设备、做为发送消息的客户端和请求订阅的客户端端之间的中介。服务端:

1) 接受来自客户端的网络链接

2) 接受客户端发布的应用消息

3) 处理客户端的订阅和取消订阅请求

4) 转发应用消息给符合条件的已订阅客户端

(4) 订阅(Subscription

     订阅包含一个主题过滤器(Topic Filter)和一个最大的服务质量(QoS)等级。订阅与单个会话(Session)关联。会话能够包含对于一个的订阅。会话的每一个订阅都有一个不一样的主题过滤器。

(5) 主题名(Topic Name

      附加在应用消息上的一个标签,服务端已知且与订阅匹配。服务端发送应用消息的一个副本给每个匹配的客户端订阅。

(6) 主题过滤器(Topic Filter

      订阅中包含的一个表达式,用于表示相关的一个或多个主题。主题过滤器可使用通配符

(7) 会话(Session

      客户端和服务端之间的状态交互。一些会话持续时间长和网络链接同样,另外一些能够在客户端和服务端的多个连续网络链接间扩展。

(8) 控制报文(MQTT Control Packet

      经过网络链接发送的信息数据包。MQTT规范定义了十四种不一样类型的控制报文,其中一个(PUBLISH报文)用于传输应用消息。

 

五.MQTT 控制报文

       MQTT协议经过交换预约义的MQTT控制报文来通讯。MQTT控制报文由三部分组成,分别是:固定报头(全部报文都包含)、可变报头(部分报文包含)、有效载荷(部分报文包含)

Fixed header

固定报头

Variable header

可变报头

Payload

有效载荷

 

(1)固定报头 Fixed header

        每一个MQTT控制报文都包含一个固定报头,固定报头的格式以下:

Bit

7

6

5

4

3

2

1

0

byte 1

MQTT控制报文的类型

用于指定报文类型的标志位

Byte 2 ...

剩余长度

 

 

MQTT 控制报文的类型(固定报头第一个字节,二进制7-4):

名字

报文流动方向

描述

Reserved

0

禁止

保留

CONNECT

1

客户端到服务端

链接服务端

CONNACK

2

服务端到客户端

确认链接请求

PUBLISH

3

两个方向都容许

发布消息

PUBACK

4

两个方向都容许

发布确认

PUBREC

5

两个方向都容许

发布收到(QoS2,第一步)

PUBREL

6

两个方向都容许

发布释放(QoS2,第二步)

PUBCOMP

7

两个方向都容许

发布完成(QoS2,第三步)

SUBSCRIBE

8

客户端到服务端

订阅主题

SUBACK

9

服务端到客户端

订阅确认

UNSUBSCRIBE

10

客户端到服务端

取消订阅

UNSUBACK

11

服务端到客户端

取消订阅确认

PINGREQ

12

客户端到服务端

心跳请求

PINGRESP

13

服务端到客户端

心跳响应

DISCONNECT

14

客户端到服务端

断开链接

Reserved

15

禁止

保留

 

报文标志Flag(固定报头,第一个字节3-0

每种报文都对应了相关的标志位,标志位以下表所列,若是收到非法的标志,接收者 必须关闭网络链接。报文标志列表以下:

控制报文

固定报头标志

Bit 3

Bit 2

Bit 1

Bit 0

CONNECT

Reserved

0

0

0

0

CONNACK

Reserved

0

0

0

0

PUBLISH

Userd in MQTT 3.1.1

DUP1

QoS2

QoS2

RETAIN3

PUBACK

Reserved

0

0

0

0

PUBREC

Reserved

0

0

0

0

PUBREL

Reserved

0

0

1

0

PUBCOMP

Reserved

0

0

0

0

SUBSCRIBE

Reserved

0

0

1

0

SUBACK

Reserved

0

0

0

0

UNSUBSCRIBE

Reserved

0

0

1

0

UNSUBACK

Reserved

0

0

0

0

PINGREQ

Reserved

0

0

0

0

PINGRESP

Reserved

0

0

0

0

DISCONNECT

Reserved

0

0

0

0

 

DUP1   = 控制报文的重复分发标志

QoS2   = PUBLISH报文的服务质量等级

RETAIN3  = PUBLISH报文的保留标志

 

剩余长度(固定报头,第二个字节开始,最大4个字节):

剩余长度(Remaining Length)表示当前报文剩余部分的字节数,包含可变报头和负载的数据。剩余长度不包括用于编码剩余长度字段自己的字节数。

剩余长度字段使用一个变长度编码方案,对于小于128的值它使用单字节编码。更大的值下面的方式处理。低7位有效位用于编码数据,最高有效位用于指示是否有更多的字节,且按照大端方式进行编码。所以每一个字节能够编码128个数值和一个延续位。剩余长度字节最大4个字节。

字节数

最小值

最大值

1

0(0x00)

127(0x7F)

2

128(0x80,0x01)

16383(0xFF,0x7F)

3

16384(0x80,0x80,0x01)

2097151(0xFF,0xFF,0x7F)

4

2097152(0x80,0x80,0x80,0x01)

268435455(0xFF,0xFF,0xFF,0x7F)

 

 

 

 

(2)可变报头 Variable header

      某些MQTT控制报文包含一个可变头部分。它在固定报头和负载之间。可变报头的内容根据报文类型的不一样而不一样,可变报头的报文标识符字段存在于多个类型的报文里。

报文标识符结构以下:

Bit

7-0

byte 1

报文标识符MSB(字符串长度的最高有效字节)

byte 2

报文标识符LSB(字符串长度的最低有效字节)

 

以下列举了那些MQTT控制报文须要报文标识符

控制报文

报文标识符字段

CONNECT

不须要

CONNACK

不须要

PUBLISH

须要(若是QoS > 0

PUBACK

须要

PUBREC

须要

PUBREL

须要

PUBCOMP

须要

SUBSCRIBE

须要

SUBACK

须要

UNSUBSCRIBE

须要

UNSUBACK

须要

PINGREQ

不须要

PINGRESP

不须要

DISCONNECT

不须要

 

 

 

 

(3)有效载荷 Payload

   某些MQTT控制报文在报文的最后部分包含一个有效载荷,以下是包含有效载荷的控制报文列表:

控制报文

报文标识符字段

CONNECT

须要

CONNACK

不须要

PUBLISH

可选

PUBACK

不须要

PUBREC

不须要

PUBREL

不须要

PUBCOMP

不须要

SUBSCRIBE

须要

SUBACK

须要

UNSUBSCRIBE

须要

UNSUBACK

不须要

PINGREQ

不须要

PINGRESP

不须要

DISCONNECT

不须要

相关文章
相关标签/搜索