MQTT(消息队列遥测传输)
MQTT(Message Queuing Telemetry Transport)是IBM开发的一种针对移动终端设备的基于TCP/IP的网络应用层的轻量级的提供发布/订阅的消息推送模式的协议,连接大量的远程传感器和控制设备,使设备对设备之间的短消息通信变得简单,比如现在应用广泛的低功耗传感器,手机、嵌入式计算机、微型控制器等移动设备。它是为硬件性能低下的远程设备以及网络状况糟糕的情况下而设计的发布/订阅型消息协议。
一、使用场景
- 不可靠、网络带宽小的网络
- 运行的设备CPU、内存非常有限
在物联网(IoT)上应用较多
MQTT协议是针对如下情况设计的:
M2M(Machine to Machine) communication,机器端到端通信,比如传感器之间的数据通讯
因为是Machine to Machine,需要考虑:
Machine(设备),比如温度传感器,硬件能力很弱,协议要考虑尽量小的资源消耗,比如计算能力和存储等
M2M可能是无线连接,网络不稳定,带宽也比较小
二、特点
MQTT协议是为大量计算能力有限,且工作在低带宽、不可靠的网络的远程传感器和控制设备通讯而设计的协议
- 基于发布/订阅模型的协议,提供一对多的消息发布,解除应用程序耦合
这一点很类似于XMPP,但是MQTT的信息冗余远小于XMPP,因为XMPP使用XML格式文本来传递数据。
- 对负载内容屏蔽的消息传输
- 使用 TCP/IP 提供网络连接
主流的MQTT是基于TCP连接进行数据推送的,但是同样有基于UDP的版本,叫做MQTT-SN。这两种版本由于基于不同的连接方式,优缺点自然也就各有不同了。
- 是二进制协议,二进制的特点就是紧凑、占用空间小。协议头只有2个字节 。小型传输,开销很小,协议交换最小化,以降低网络流量。这就是为什么在介绍里说它非常适合"在物联网领域,传感器与服务器的通信,信息的收集",要知道嵌入式设备的运算能力和带宽都相对薄弱,使用这种协议来传递消息再适合不过了。
- 提供了三种消息可能性保障(Qos):0:最多一次 、1:最少一次 、2:只有一次
最多一次:消息发布完全依赖底层 TCP/IP 网络。会发生消息丢失或重复。这一级别可用于如下情况,环境传感器数据,丢失一次读记录无所谓,因为不久后还会有第二次发送