物联网(Internet of Things,IoT)最近曝光率越来越高。虽然HTTP是网页的事实标准,不过机器之间(Machine-to-Machine,M2M)的大规模沟通需要不同的模式:之前的请求/回答(Request/Response)模式不再合适,取而代之的是发布/订阅(Publish/Subscribe)模式。这就是轻量级、可扩展的MQTT(Message Queuing Telemetry Transport)可以施展拳脚的舞台。

由于物联网的环境是非常特别的,所以MQTT遵循以下设计原则:

  1. 精简,不添加可有可无的功能。
  2. 发布/订阅(Pub/Sub)模式,方便消息在传感器之间传递。
  3. 允许用户动态创建主题,零运维成本。
  4. 把传输量降到最低以提高传输效率。
  5. 把低带宽、高延迟、不稳定的网络等因素考虑在内。
  6. 支持连续的会话控制。
  7. 理解客户端计算能力可能很低。
  8. 提供服务质量管理。
  9. 假设数据不可知,不强求传输数据的类型与格式,保持灵活性。

发布/订阅模式

与请求/回答这种同步模式不同,发布/定义模式解耦了发布消息的客户(发布者)与订阅消息的客户(订阅者)之间的关系,这意味着发布者和订阅者之间并不需要直接建立联系。打个比方,你打电话给朋友,一直要等到朋友接电话了才能够开始交流,是一个典型的同步请求/回答的场景;而给一个好友邮件列表发电子邮件就不一样,你发好电子邮件该干嘛干嘛,好友们到有空了去查看邮件就是了,是一个典型的异步发布/订阅的场景。
熟悉编程的同学一定非常熟悉这种设计模式了,因为它带来了这些好处:

  1. 发布者与订阅者不比了解彼此,只要认识同一个消息代理即可。
  2. 发布者和订阅者不需要交互,发布者无需等待订阅者确认而导致锁定。
  3. 发布者和订阅者不需要同时在线,可以自由选择时间来消费消息。

主题

MQTT是通过主题对消息进行分类的,本质上就是一个UTF-8的字符串,不过可以通过反斜杠表示多个层级关系。主题并不需要创建,直接使用就是了。
主题还可以通过通配符进行过滤。其中,+可以过滤一个层级,而*只能出现在主题最后表示过滤任意级别的层级。举个例子:

  • building-b/floor-5:代表B楼5层的设备。
  • +/floor-5:代表任何一个楼的5层的设备。
  • building-b/*:代表B楼所有的设备。

注意,MQTT允许使用通配符订阅主题,但是并不允许使用通配符广播。

服务质量

为了满足不同的场景,MQTT支持三种不同级别的服务质量(Quality of Service,QoS)为不同场景提供消息可靠性:

  1. 级别0:尽力而为。消息发送者会想尽办法发送消息,但是遇到意外并不会重试。
  2. 级别1:至少一次。消息接收者如果没有知会或者知会本身丢失,消息发送者会再次发送以保证消息接收者至少会收到一次,当然可能造成重复消息。
  3. 级别2:恰好一次。保证这种语义肯待会减少并发或者增加延时,不过丢失或者重复消息是不可接受的时候,级别2是最合适的。

服务质量是个老话题了。级别2所提供的不重不丢很多情况下是最理想的,不过往返多次的确认一定对并发和延迟带来影响。级别1提供的至少一次语义在日志处理这种场景下是完全OK的,所以像Kafka这类的系统利用这一特点减少确认从而大大提高了并发。级别0适合鸡肋数据场景,食之无味弃之可惜,就这么着吧。

消息类型

MQTT拥有14种不同的消息类型:

  1. CONNECT:客户端连接到MQTT代理
  2. CONNACK:连接确认
  3. PUBLISH:新发布消息
  4. PUBACK:新发布消息确认,是QoS 1给PUBLISH消息的回复
  5. PUBREC:QoS 2消息流的第一部分,表示消息发布已记录
  6. PUBREL:QoS 2消息流的第二部分,表示消息发布已释放
  7. PUBCOMP:QoS 2消息流的第三部分,表示消息发布完成
  8. SUBSCRIBE:客户端订阅某个主题
  9. SUBACK:对于SUBSCRIBE消息的确认
  10. UNSUBSCRIBE:客户端终止订阅的消息
  11. UNSUBACK:对于UNSUBSCRIBE消息的确认
  12. PINGREQ:心跳(空闲时发一个)
  13. PINGRESP:确认心跳
  14. DISCONNECT:客户端终止连接前优雅地通知MQTT代理

MQTT代理

市面上有相当多的高质量MQTT代理,其中mosquitto是一个开源的轻量级的C实现,完全兼容了MQTT 3.1和MQTT 3.1.1。下面我们就以mosquitto为例演示一下MQTT的使用。环境是Ubuntu 14.04.1 LTS,简单起见MQTT代理和客户端都安装在同一台服务器上了。
安装mosquitto以及搭配的客户端:

sudo apt-get install mosquitto mosquitto-clients 

简单测试

一个完整的MQTT示例包括一个代理器,一个发布者和一个订阅者。测试分为以下几个步骤:

  1. 启动服务mosquitto。
  2. 订阅者通过mosquitto_sub订阅指定主题的消息。
  3. 发布者通过mosquitto_pub发布指定主题的消息。
  4. 代理服务器把该主题的消息推送到订阅者。

在本例中,发布者、代理和订阅者均为localhsot,但是在实际的情况下三种并不是同一个设备,在mosquitto中可通过-h(--host)设置主机名称(hostname)。为了实现这个简单的测试案例,需要在linux中打开三个控制台,分别代表代理服务器、发布者和订阅者。

启动代理服务

mosquitto -v
【-v】打印更多的调试信息

订阅主题

mosquitto_sub -v -t sensor
【-t】指定主题,此处为sensor
【-v】打印更多的调试信息

发布内容

mosquitto_pub -t sensor -m 12
【-t】指定主题
【-m】指定消息内容

运行结果

当发布者推送消息之后,订阅者获得以下内容
sensor 12
而代理服务器控制台中会出现——连接、消息发布和心跳等调试信息。通过代理服务器的调试输出可以对MQTT协议的相关过程有所了解。

mosquitto更多安装:https://mosquitto.org/download/

MQTT Mosquitto安装和使用相关推荐

  1. 在ubuntu上安装,使用MQTT Mosquitto

    这是一种相对简单的安装办法,不用去下载源码后再编译安装,省去了编译和运行过程中出现的各种错误和安装各种依赖库. 在ubuntu上安装,使用MQTT Mosquitto 以下描述了如何安装Mosquit ...

  2. MQTT的学习之Mosquitto安装使用(1)

    Mosquitto是一个实现了MQTT3.1协议的代理服务器,由MQTT协议创始人之一的Andy Stanford-Clark开发,它为我们提供了非常棒的轻量级数据交换的解决方案.本文的主旨在于记录M ...

  3. python mqtt broker_python Mqtt 的安装及使用

    简介&安装 MQTT是一个基于客户端-服务器的消息发布/订阅传输协议.MQTT协议是轻量.简单.开放和易于实现的,这些特点使它适用范围非常广泛.可以以极少的代码和有限的带宽,为连接远程设备提供 ...

  4. 【MQTT】MQTT简介+安装+使用

    目录 前言 MQTT 协议简介 为何选择 MQTT MQTT 通讯运作方式 MQTT 协议帧格式 MQTT服务器搭建和使用 公共MQTT 测试服务器 MQTT服务器搭建 各种MQTT代理服务程序比较 ...

  5. mosquitto安装与使用

    Eclipse Mosquitto 是实现MQTT协议版本5.0.3.1.1和3.1的开源消息代理(经EPL / EDL许可). mosquitto 是一个开源的轻量级的C实现,适合在从低功耗单板计算 ...

  6. Mosquitto安装和测试

    MQTT相关实验 第一节:Mosquitto 相关实验 第二节:域名解析和内网穿透实验 第三节:OneNET 相关实验 Gitee仓库地址: https://gitee.com/zhj0125/MQT ...

  7. Mosquitto安装

    mosquitto是一款开源免费的软件,官网链接.它是一些可执行文件的集合,通过这些可执行文件,它提供broker,publish,subscribe功能.安装mosquitto一般是为了让它作为MQ ...

  8. mosquitto 安装 centos7

    centos7 : cd ~ yum install openssl-devel yum install gcc-c++ yum install libuuid-devel yum install m ...

  9. windows上mosquitto安装及简单使用

    windows上mosquitto安装及简单使用 1.从官网上下载 https://mosquitto.org/download/ 2.安装 3.配置文件&启动mosquitto Broker ...

最新文章

  1. 复合的赋值运算符例题_Java千问:关于Java语言复合赋值运算符的两个问题,快来瞧瞧!...
  2. okhttp上传文件结束后服务器才收到,okhttp3 Null Respone上传文件
  3. 深度学习tensorflow框架的张量
  4. python:列表推导式
  5. pd怎么卸载linux系统,parallels desktop11怎么卸载?parallels desktop11卸载方法
  6. linux系统时间函数,Linux时间时区详解与常用时间函数
  7. android 阅读器上下滑动_科研党利器——文石13.3寸墨水屏阅读器BOOX Max3
  8. python生成随机数方法_详解用python生成随机数的几种方法
  9. SHELL TIPS: GNU SCREEN 的一些小技巧
  10. 洛谷1309 瑞士轮 解题报告
  11. Visio实用技巧总结
  12. oracle报错ora-12162,sqlplus登录提示:ORA-12162错误
  13. AMD OpenCL Programming Guide - OpenCL Architecture
  14. 【Web技术】662- 玩转前端 Video 播放器
  15. android 计步器 计算当前的行走步数
  16. 《MLB棒球创造营》:走近棒球运动·圣路易斯红雀队
  17. win10无法识别光驱的解决方法
  18. HCSA-08 威胁防护介绍、ARP防护、网络攻击防护、病毒过滤、入侵防御、边界流量过滤
  19. 20多年前微软曾计划收购,任天堂嘲讽道:“笑死我了”
  20. 湖北计算机技术以考代评,目前有哪些专业技术资格即职称实行“以考代评”?...

热门文章

  1. 如何学习大型项目的源码?
  2. mac 文字识别软件ocr_mac超快速ocr文字识别软件 mac上超好用的文字识别软件推荐...
  3. 论文阅读《Learning for Disparity Estimation through Feature Constancy》
  4. 中国第一台103型电子计算机诞生于,第一台计算机诞生于几年?
  5. W ndows 10模拟器,手机windows10模拟器
  6. Ubuntu下安装Nvidia和Intel双显卡驱动
  7. 给大家介绍一个PDF图书下载网站,还有TXT图书下载
  8. 沉浸式状态栏实现,完美适配Android刘海屏,终极兼容
  9. Linux下的常用编程工具初探
  10. python中loads和dumps,load和dump的区别