MQTT是一个客户端服务端架构的发布/订阅模式的消息传输协议。主要应用于机器与机器(M2M)以及物联网的环境。
摘要
MQTT是一个
客户端服务端架构的
发布/订阅模式的消息传输协议。主要应用于机器与机器(M2M)以及物联网的环境(IoT)。
该协议运行在
TCP/IP,或其他提供了
有序、可靠、双向链接的网络链接上。它有以下特点:
-
使用发布/订阅消息模式,提供了一堆多的消息分布和应用之间的解耦。
-
消息传输不需要知道负载内容
-
提供 三种等级的服务质量(QoS):
-
“ 最多一次”,尽操作环境所能提供的最大努力分发消息。消息可能丢失。例如,这个等级可用于环境传感数据,单次数据丢失没关系,因为不久之后会再次发送。
-
“ 至少一次”,保证消息可以到达,但是可能会重复。
-
“ 仅一次”,保证消息只到达一次。例如,这个等级可用在一个计费系统中,这里如果消息重复或丢失会导致不正确的收费。
-
很小的传输消耗和协议数据交换,最大限度减少网络流量。
-
异常链接断开时,能通知到相关各方。
术语
网络连接:MQTT使用的底层传输协议基础设施。客户端使用它连接服务端;它提供有序的、可靠的、双向字节流传输。
应用消息:MQTT协议通过网络传输应用数据。应用消息通过MQTT传输时,它们有关联的服务质量(QoS)和主题(Topic)。
客户端:使用MQTT的程序或设备。客户端总是通过网络连接到服务端。它可以发布消息、订阅消息、取消订阅消息、与服务器断开连接
。
服务端:一个程序或设备,作为发送消息的客户端和请求订阅的客户端之间的中介。服务端接收来自客户端的网络连接,接收客户端发布的应用消息,处理客户端的订阅和取消订阅消息,转发应用消息给符合条件的已订阅客户端。
订阅:订阅包含一个主题过滤器和一个最大的服务质量等级。订阅和单个会话关联。会话可以包含多余一个的订阅。会话的每个订阅都有一个不同的主题过滤器。
主题名:附加在应用消息上的一个标签,服务端已知且与订阅匹配。服务端发送应用消息的一个副本给每一个匹配的客户端订阅。
主题过滤器:订阅中包含的一个表达式,用于表示相关的一个或多个主题。主题过滤器可以使用通配符。
会话:客户端和服务端之间的状态交互。一些会话持续时长与网络连接一样,另一些可以在客户端和服务端的多个连接网络连接件扩展。
控制报文:通过网络连接发送的信息数据包。MQTT规范定义了十四种不同类型的控制报文,其中一个(PUBLISH报文)用于传输应用消息。
UTF-8使用1~4字节为每个字符编码。
UTF-8编码字符串中的字符数据必须是按照Unicode规范 [Unicode] 定义的和在RFC3629 [RFC3629] 中重申的有效的UTF-8格式。特别需要指出的是,这些数据不能包含字符码在U+D800和U+DFFF之间的数据。如果服务端或客户端收到了一个包含无效UTF-8字符的控制报文,它必须关闭网络连接 [MQTT-1.5.3-1]。
UTF-8编码的字符串不能包含空字符U+0000。如果客户端或服务端收到了一个包含U+0000的控制报文,它必须关闭网络连接 [MQTT-1.5.3-2]。
数据中不应该包含下面这些Unicode代码点的编码。如果一个接收者(服务端或客户端)收到了包含下列任意字符的控制报文,它可以关闭网络连接:
-
U+0001和U+001F之间的控制字符
-
U+007F和U+009F之间的控制字符
-
Unicode规范定义的非字符代码点(例如U+0FFFF)
-
Unicode规范定义的保留字符(例如U+0FFFF)