MQTT协议中文版
目錄
介紹
第一章 - MQTT介绍
第二章 – MQTT控制报文格式
第三章 – MQTT控制报文
3.1 CONNECT – 连接服务端
3.2 CONNACK – 确认连接请求
3.3 PUBLISH – 发布消息
3.4 PUBACK –发布确认
3.5 PUBREC – 发布收到(QoS 2,第一步)
3.6 PUBREL – 发布释放(QoS 2,第二步)
3.7 PUBCOMP – 发布完成(QoS 2,第三步)
3.8 SUBSCRIBE - 订阅主题
3.9 SUBACK – 订阅确认
3.10 UNSUBSCRIBE –取消订阅
3.11 UNSUBACK – 取消订阅确认
3.12 PINGREQ – 心跳请求
3.13 PINGRESP – 心跳响应
3.14 DISCONNECT –断开连接
第四章 – 操作行为
第五章 – 安全
第六章 – 使用WebSocket
第七章 – 一致性目标
附录B - 强制性规范声明
0
1
2
3
3.1
3.2
3.3
3.4
3.5
3.6
3.7
3.8
3.9
3.10
3.11
3.12
3.13
3.14
4
5
6
7
8
2
MQTT协议中文版
MQTT协议中文版
by mcxiaoke
最新版本: v1.0.3 2016.02.06
文档地址
MQTT协议中文版
PDF和ePub下载
中文翻译项目
概述
MQTT是一个客户端服务端架构的发布/订阅模式的消息传输协议。它的设计思想是轻巧、开
放、简单、规范,易于实现。这些特点使得它对很多场景来说都是很好的选择,特别是对于
受限的环境如机器与机器的通信(M2M)以及物联网环境(IoT)。
说明
MQTT英文原版协议提供了Word格式和HTML格式,我翻译的时候用的Word文档,之前
一直提供的是Word文档转换的HTML和PDF共浏览和下载,最近花时间整理了Markdown
版本,可以更方便的分章节在线浏览了,转换为Markdown后部分表格的格式不太对,会
逐步用图片代替。
目录
发现任何翻译问题或格式问题欢迎提PR帮忙完善。
说明
前言
目录
第一章 - MQTT介绍
第二章 – MQTT控制报文格式
第三章 – MQTT控制报文
3.1 CONNECT – 连接服务端
介紹
3
MQTT协议中文版
3.2 CONNACK – 确认连接请求
3.3 PUBLISH – 发布消息
3.4 PUBACK –发布确认
3.5 PUBREC – 发布收到(QoS 2,第一步)
3.6 PUBREL – 发布释放(QoS 2,第二步)
3.7 PUBCOMP – 发布完成(QoS 2,第三步)
3.8 SUBSCRIBE - 订阅主题
3.9 SUBACK – 订阅确认
3.10 UNSUBSCRIBE –取消订阅
3.11 UNSUBACK – 取消订阅确认
3.12 PINGREQ – 心跳请求
3.13 PINGRESP – 心跳响应
3.14 DISCONNECT –断开连接
第四章 – 操作行为
第五章 – 安全
第六章 – 使用WebSocket
第七章 – 一致性目标
附录B - 强制性规范声明
旧版文档
已过期,建议使用GitBook版本 最新版本: v1.0.1 2015.10.22
文档
连接
中文版 HTML
中文版 PDF
英文版 HTML
英文版 PDF
许可协议
MQTT 3.1.1 中文版
MQTT 3.1.1 中文版
MQTT Version 3.1.1
MQTT Version 3.1.1
署名-非商业性使用-相同方式共享 4.0 国际
联系方式
介紹
4
MQTT协议中文版
Blog: http://blog.mcxiaoke.com
Github: https://github.com/mcxiaoke
Email: github@mcxiaoke.com
开源项目
Rx文档中文翻译: https://github.com/mcxiaoke/RxDocs
MQTT协议中文版: https://github.com/mcxiaoke/mqtt
Awesome-Kotlin: https://github.com/mcxiaoke/awesome-kotlin
Kotlin-Koi: https://github.com/mcxiaoke/kotlin-koi
Next公共组件库: https://github.com/mcxiaoke/Android-Next
PackerNg极速打包: https://github.com/mcxiaoke/packer-ng-plugin
Gradle渠道打包: https://github.com/mcxiaoke/gradle-packer-plugin
EventBus实现xBus: https://github.com/mcxiaoke/xBus
蘑菇饭App: https://github.com/mcxiaoke/minicat
饭否客户端: https://github.com/mcxiaoke/fanfouapp-opensource
Volley镜像: https://github.com/mcxiaoke/android-volley
介紹
5
MQTT协议中文版
第一章 概述 Introduction
1.1 MQTT协议的组织结构 Organization of MQTT
本规范分为七个章节:
第一章 - 介绍
第二章 – MQTT控制报文格式
第三章 – MQTT控制报文
第四章 – 操作行为
第五章 – 安全
第六章 – 使用WebSocket
第七章 – 一致性目标
附录B - 强制性规范声明
1.2 术语 Terminology
本规范中用到的关键字 必须 MUST,不能 MUST NOT,要求 REQUIRED,将会 SHALL,不
会 SHALL NOT,应该 SHOULD,不应该 SHOULD NOT,推荐 RECOMMENDED,可以
MAY,可选 OPTIONAL 都是按照 IETF RFC 2119 [RFC2119] 中的描述解释。
网络连接 Network Connection
MQTT使用的底层传输协议基础设施。
客户端使用它连接服务端。
它提供有序的、可靠的、双向字节流传输。
例子见4.2节。
应用消息 Application Message MQTT协议通过网络传输应用数据。应用消息通过MQTT传
输时,它们有关联的服务质量(QoS)和主题(Topic)。
客户端 Client
使用MQTT的程序或设备。客户端总是通过网络连接到服务端。它可以
发布应用消息给其它相关的客户端。.
订阅以请求接受相关的应用消息
取消订阅以移除接受应用消息的请求。
从服务端断开连接。
第一章 - MQTT介绍
6
MQTT协议中文版
服务端 Server 一个程序或设备,作为发送消息的客户端和请求订阅的客户端之间的中介。服
务端
接受来自客户端的网络连接
接受客户端发布的应用消息
处理客户端的订阅和取消订阅请求。
转发应用消息给符合条件的客户端订阅。
订阅 Subscription 订阅包含一个主题过滤器(Topic Filter)和一个最大的服务质量(QoS)
等级。订阅与单个会话(Session)关联。会话可以包含多于一个的订阅。会话的每个订阅都
有一个不同的主题过滤器。
主题名 Topic Name **附加在应用消息上的一个标签,服务端已知且与订阅匹配。服务端发送
应用消息的一个副本给每一个匹配的客户端订阅。
主题过滤器 Topic Filter 订阅中包含的一个表达式,用于表示相关的一个或多个主题。主题过
滤器可以使用通配符。
会话 Session **客户端和服务端之间的状态交互。一些会话持续时长与网络连接一样,另一
些可以在客户端和服务端的多个连续网络连接间扩展。
控制报文 MQTT Control Packet 通过网络连接发送的信息数据包。MQTT规范定义了十四种
不同类型的控制报文,其中一个(PUBLISH报文)用于传输应用消息。
1.5 数据表示 Data representations
1.5.1 二进制位 Bits
字节中的位从0到7。第7位是最高有效位,第0位是最低有效位。
1.5.2 整数数值 Integer data values
整数数值是16位,使用大端序(big-endian,高位字节在低位字节前面)。这意味着一个16位
的字在网络上表示为最高有效字节(MSB),后面跟着最低有效字节(LSB)。
1.5.3 UTF-8编码字符串 UTF-8 encoded strings
后面会描述的控制报文中的文本字段编码为UTF-8格式的字符串。UTF-8 [RFC3629] 是一个
高效的Unicode字符编码格式,为了支持基于文本的通信,它对ASCII字符的编码做了优化。
每一个字符串都有一个两字节的长度字段作为前缀,它给出这个字符串UTF-8编码的字节数,
它们在图例 1.1 UTF-8编码字符串的结构 中描述。因此可以传送的UTF-8编码的字符串大小有
一个限制,不能超过 65535字节。
第一章 - MQTT介绍
7
MQTT协议中文版
除非另有说明,所有的UTF-8编码字符串的长度都必须在0到65535字节这个范围内。
图例 1.1 UTF-8编码字符串的结构 Structure of UTF-8 encoded strings
二进制位
byte 1
byte 2
byte 3 ….
7-0
字符串长度的最高有效字节(MSB)
字符串长度的最低有效字节(LSB)
如果长度大于0,这里是UTF-8编码的字符数据。
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)
UTF-8编码序列0XEF 0xBB 0xBF总是被解释为U+FEFF(零宽度非换行空白字符),无论它
出现在字符串的什么位置,报文接收者都不能跳过或者剥离它 [MQTT-1.5.3-3]。
非规范示例 Non normative example
例如,字符串 A 是一个拉丁字母A后面跟着一个代码点U+2A6D4(它表示一个中日韩统
一表意文字扩展B中的字符),这个字符串编码如下:
图例 1.2 UTF-8编码字符串非规范示例 UTF-8 encoded string non normative example
第一章 - MQTT介绍
8