xuos-web/docs/doc/communication/mymqtt.md

31 lines
3.1 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# mymqtt
## Mqtt简介
<el-divider></el-divider>
MQTTMessage Queuing Telemetry Transport消息队列遥测传输协议是一种基于发布/订阅publish/subscribe模式的"轻量级"通讯协议该协议构建于TCP/IP协议上由IBM在1999年发布。MQTT最大优点在于可以以极少的代码和有限的带宽为连接远程设备提供实时可靠的消息服务。作为一种低开销、低带宽占用的即时通讯协议使其在物联网、小型设备、移动应用等方面有较广泛的应用。</br></br>
MQTT是一个基于客户端-服务器的消息发布/订阅传输协议。MQTT协议是轻量、简单、开放和易于实现的这些特点使它适用范围非常广泛。在很多情况下包括受限的环境中机器与机器M2M通信和物联网IoT。其在通过卫星链路通信传感器、偶尔拨号的医疗设备、智能家居、及一些小型化设备中已广泛使用。</br></br>
## 主要特性
<el-divider></el-divider>
MQTT协议工作在低带宽、不可靠的网络的远程传感器和控制设备通讯而设计的协议它具有以下主要的几项特性
+ 1使用发布/订阅消息模式,提供一对多的消息发布,解除应用程序耦合。</br>
这一点很类似于XMPP但是MQTT的信息冗余远小于XMPP,因为XMPP使用XML格式文本来传递数据。
+ 2对负载内容屏蔽的消息传输。
+ 3使用TCP/IP提供网络连接。</br>
主流的MQTT是基于TCP连接进行数据推送的但是同样有基于UDP的版本叫做MQTT-SN。这两种版本由于基于不同的连接方式优缺点自然也就各有不同了。
+ 4有三种消息发布服务质量</br>
"至多一次"消息发布完全依赖底层TCP/IP网络。会发生消息丢失或重复。这一级别可用于如下情况环境传感器数据丢失一次读记录无所谓因为不久后还会有第二次发送。这一种方式主要普通APP的推送倘若你的智能设备在消息推送时未联网推送过去没收到再次联网也就收不到了。</br>
"至少一次",确保消息到达,但消息重复可能会发生。</br>
"只有一次"确保消息到达一次。在一些要求比较严格的计费系统中可以使用此级别。在计费系统中消息重复或丢失会导致不正确的结果。这种最高质量的消息发布服务还可以用于即时通讯类的APP的推送确保用户收到且只会收到一次。
+ 5小型传输开销很小固定长度的头部是2字节协议交换最小化以降低网络流量。</br>
这就是为什么在介绍里说它非常适合"在物联网领域,传感器与服务器的通信,信息的收集",要知道嵌入式设备的运算能力和带宽都相对薄弱,使用这种协议来传递消息再适合不过了。
+ 6使用Last Will和Testament特性通知有关各方客户端异常中断的机制。</br>
Last Will即遗言机制用于通知同一主题下的其他设备发送遗言的设备已经断开了连接。
Testament遗嘱机制功能类似于Last Will。