什么是MQTT

article/2025/9/11 23:54:57

1、MQTT来龙去脉

1.1 什么是MQTT

        MQTT(英文全称Message Queuing Telemetry Transport,消息队列遥测传输协议)是一种基于发布/订阅(PUBLISH/SUBSCRIBE)模式的轻量级的物联网通信协议。从这个定义中我们可以总结出四个关键词:消息队列、遥测技术(telemetry)、发布/订阅、轻量级。下面将针对这四个关键词分别做出解释。

        消息队列(MQ)是一种非常常见的异步分发和处理模型,有着广泛的应用。其基本构成是生产-转存-消费[1],也就是生产者产生消息,然后在队列中进行缓存,再由消费者从队列中取消息,这是一种最简单的点对点的场景。还有一种点对多点的场景,即需要将一份消息分发给多个消费者(类似于网络通信中的组播),这就是我们的这里提到的发布/订阅模型。所谓的发布/订阅模型本质上也是由生产者负责发布消息,只不过这个消息增加了一个topic主题,并且缓存在队列中,这样就可以有多个消费者同时订阅这个主题。详细的过程如下图所示。

        那什么是遥测技术?遥感勘测技术起初是应用在卫星,太空探索和移动机器人领域,用来无线传送和接收远程监控环境情况或设备参数的测量数据,此处被引入到物联网领域,是一种云端从远端的感知层采集数据的技术。至于说轻量级,后面对该协议报文头的解析可以看出只有两到三个字节,从这一点上就可以大大节省对网络和计算资源的消耗。详细解读了什么是MQTT以后,接下来就看一下这个协议的发展史,可以帮助我们更好地理解协议演进的方向,以及为何会发生这样的变化。

1.2 MQTT协议发展史

        MQTT协议是由IBM公司在1999年提出的,截至到目前一共有5个正式版本,其中最新的版本是v5。在这5个版本中有一个特殊的版本,即专门应用于传感器网络的MQTT-SN,该版本主要应用在传感器等资源受限的场景,很难在传感器上支持tcp协议,为了入网也会有特殊的设备和架构。两者的差异如下图所示。

       

        主流MQTT协议各个版本的差异进行分析,如下表所示。各个版本基本上都是围绕上面的6个维度去变化的。安全性上来讲主要是引入一些新的鉴权机制,同时在信息来源上做到可以溯源,安全一直是物联网的一个痛点,作为物联网事实上的标准协议,MQTT后续也会在安全性方面有更多的考虑。可靠性方面主要是保证通信双方在发生异常时,能够得到反馈,是因为能力不支持还是网络异常导致的通信问题,从而进行相应地处理。物联网的资源特别是终端侧其实是非常受限的,即使是在网络层上随着接入终端的增多,其资源也是十分宝贵的,因此如何在保证可靠通信的前提下,更合理地分配网络和计算资源也是协议演进要重点考量的点。至于说可扩展性和兼容性则是每种网络协议在往前演进的过程中都需要考虑的,要能保证在不同的平台上,不同的应用场景下,都可以灵活地扩展和使用。

1.3 MQTT协议特点

       从MQTT协议的应用场景来看,主要是应用在物联网场景,物联网通信的特点是海量客户端连接到服务器,这个数量级会在亿级以上,需要协议足够简单;由于客户端移动的特性,通常是通过无线接入的方式,通信的环境比较差,因此要求协议要具备良好地通信质量;另外客户端的设备都是比较小的智能终端,处理能力较差,这就要求协议报文必须足够短小和简单。

        鉴于以上物联网通信的特点和要求,MQTT协议在设计时很好地解决了这些问题,具有如下地特点:

1)报文头采用二进制方式,以位计算,极大地控制了报文长度,因此足够轻量级。

2)引入qos机制,保障通信的质量,同时引入心跳机制,使客户端和服务器端之间能够感知链路质量,当发生断链时,可以快速重连。

3)特性足够简单,基本上整个协议最核心的就是订阅和发布功能,无其他复杂功能。

4)具备了消息队列异步的通信方式,很好地解决了海量连接地问题。

未完待续

参考文献:

[1](71 条消息) 消息队列(mq)是什么? - 知乎 (zhihu.com)


http://chatgpt.dhexx.cn/article/80esYeWj.shtml

相关文章

设备分配与spooling技术详解

5.4 设备分配(重点!!!) 一、设备分配中的数据结构二、设备分配时应考虑的因素三、设备独立性四、设备独占的分配程序五、Spooling技术 一、设备分配中的数据结构 在进行设备分配时,通常都要借助一些表格…

SPOOLing和虚拟化

什么是虚拟化 虚拟化就是无中生有,就是暗度陈仓(狗头保命)。仔细观察整个计算机系统的设计,到处都体现着虚拟化的技术。当然虚拟化就是操作系统设计的要求之一。我们很好理解 CPU 的虚拟化技术,也就是通过进程调度实现…

操作系统 假脱机(Spooling)系统

介绍 通过多道程序技术可将一台物理CPU虚拟为多台逻辑CPU,从而允许多个用户共享一台主机。那么,假脱机技术,则可将一台物理I/O设备虚拟为多台逻辑I/O设备,这样也就允许多个用户共享一台物理I/O设备。 1. 假脱机技术 早期&#…

题目SPOOLing系统的设计与实现

最近刚刚做的一个课程设计,关于SPOOLing的。 一、算法或原理的实现思想 技术原理 SPOOLing技术可将一台物理I/O设备虚拟为多台逻辑I/O设备,同样允许多个用户共享一台物理I/O设备。SPOOLing技术把所有用户进程的输出都送入输出井,然后再由输出…

精确度,准确度,精密度关系

1.精确度,准确度,精密度的关系 三者得关系大体可以理解为,准确度精密度 精确度,准确度反应距离真值得偏差,精密度反应测量得稳定性,精确度反应二者之综合。 三者得主次关系:精密度>准确度 …

Mysql的浮点精确度

1.mysql的用于记录小数的类型有三个float ,decimal 和double他们之间的关系 先创建一个表test都用了float ,decimal 和double 插入一条数据查看发现没有发现精度丢失问题 再插入一条数据,发现精度损失: 查看三个类型的范围: 插入小数的位数多…

验证集精确度和损失同时上升

目录 1. 实验结果2. 分析 1. 实验结果 下图中val_acc,val_loss分别表示验证集精确度和损失;train_acc,train_loss分别表示训练集精确度和损失。验证集精确度一直上升,但是损失在第六个epoch后也开始上升,如何解释&…

JavaScript超大或超小数值精确度丢失解决方案

情景一 接口字段,Number类型数据失真,解决方法可直接让服务端把字段类型改成String类型即可。 情景二 某些特殊场景,需要保留小数点后9位(及其以上),直接调用Number对象自带的toFixed()函数,会出现小数点后数据失真…

关于JavaScript精确度问题

一、js精确度的安全范围是 -2^53 至 2^53 一旦超过这个范围则无法精确表示 1.解决方法 使用第三方包 JSON-Bigint JSONbig.parse() //转换出来的是一个BigNubmer对象 若要使用则用toString()方法 JSONbig.stringify() 2.当axios获取响应数据时自动会将数据JSON.parse()解析为…

【机器学习】准确率、精确度、召回率和 F1 定义

一、说明 数据科学家选择目标变量后 - 例如他们希望预测电子表格中的“列”,并完成了转换数据和构建模型的先决条件,最后步骤之一是评估模型的性能。 二、混淆矩阵的模型 2.1 混淆矩阵 选择性能指标通常取决于要解决的业务问题。假设您的数据集中有 10…

Python计算分类问题的评价指标(准确率、精确度、召回率和F1值,Kappa指标)

机器学习的分类问题常用评论指标有:准确率、精确度、召回率和F1值,还有kappa指标 。 每次调包去找他们的计算代码很麻烦,所以这里一次性定义一个函数,直接计算所有的评价指标。 每次输入预测值和真实值就可以得到上面的指标值&a…

batch_size对精确度和损失的影响

1 问题 在深度学习的学习过程中,模型性能对batchsize虽然没有学习率那么敏感,但是在进一步提升模型性能时,batch_size就会成为一个非常关键的参数。 batch_size对精度和损失的影响研究。 batch_size [,32,64,128,256] 不同batch_…

准度、精度傻傻分不清?

[导读] 做电子产品,常常遇到测量。此时就难免会关注到精度、准度等概念,遇到不少朋友对这两个概念不清楚,今天就来分享一下这两个概念。最近很忙,更的不及时,实在抱歉。也感谢大家不离不弃!对于更文分享这件…

机器学习笔记--classification_report精确度/召回率/F1值

classification_report简介 sklearn中的classification_report函数用于显示主要分类指标的文本报告.在报告中显示每个类的精确度,召回率,F1值等信息。 主要参数: y_true:1维数组,或标签指示器数组/稀疏矩阵&#xf…

YOLOv5~目标检测模型精确度

还是yolo5的基础啊~~ 一些关于目标检测模型的评估指标:IOU、TP&FP&FN&TN、mAP等,并列举了目标检测中的mAP计算。 指标评估(重要的一些定义) IOU 也称重叠度表示计算预测回归框和真实回归框的交并比,计算公式如下: TP&FP&FN&…

睿智的目标检测20——利用mAP计算目标检测精确度

睿智的目标检测20——利用mAP计算目标检测精确度 学习前言GITHUB代码下载知识储备1、IOU的概念2、TP TN FP FN的概念3、precision(精确度)和recall(召回率)4、概念举例5、单个指标的局限性 什么是AP绘制mAP 学习前言 好多人都想算…

误差与精度

机械专业用于教授学生误差与精度概念的课程叫做《公差与测量》或者叫做《机械精度设计》,而公差或者精度的本质含义就是误差的大小,公差越小,误差越小,精度越高。所以机械专业这门课其本质教授的还是误差理论。 在学校并没有好好学…

层次分析法 AHP

层次分析法(Analytic Hierarchy Process,简称 AHP)是对一些较为复杂、较为模糊的问题作出决策的简易方法,它特别适用于那些难于完全定量分析的问题。它是美国运筹学家 T. L. Saaty 教授于上世纪 70 年代初期提出的一种简便、灵活而…

权重计算方法一:层次分析法(AHP)

目录 1.层次分析法原理介绍 2.层次分析法建模步骤 3.案例分析 3.1 题目简述 3.2 确定评价指标,建立层次关系 3.3 构造判断矩阵 3.3.1 标度定义 3.3.2 构造判断矩阵 3.4 一致性检验 3.5 层次总排序 4.代码实现 1.层次分析法原理介绍 关于层次分析法的具体原…

【数学建模】层次分析法(AHP)

层次分析法 文章目录 层次分析法用途一、模型介绍一道典型例题1.建立层次结构2.对于同一层次的个元素关于上一层次中的某一准则的重要性进行两两比较,构造两两比较矩阵(判断矩阵)。2.1 O-C矩阵(确定指标的权重)2.2 准则…