最火的物联网技术MQTT,其服务质量QoS的三个级别分别是什么意思,本文一定对您有帮助!

简介: MQTT是在 TCP/IP 之上使用的轻量级发布-订阅协议,常用于物联网的场景,MQTT 使用消息代理在发布消息的发送者和对这些消息感兴趣的接收者之间分派消息,同一个客户端可以发布和订阅消息。

MQTT是在 TCP/IP 之上使用的轻量级发布-订阅协议,常用于物联网的场景,MQTT 使用消息代理在发布消息的发送者和对这些消息感兴趣的接收者之间分派消息,同一个客户端可以发布和订阅消息。

MQTT 定义了三个级别的服务质量,也就是QoS,这三种级别分别代表什么意思,估计很多使用MQTT的小伙伴没太关注,有时候你遇到问题了,特别是那种诡异的问题,更不会朝这个上面想,今天瑞哥就带大家详细的了解一下MQTT的QoS,让我们直接开始!

MQTT的消息传输过程

在展开QoS前,我们有必要知道MQTT的消息传输过程。

MQTT分别三种角色:

  • Publisher:消息的发布者
  • Broker:消息的中转地,也被称为经纪人
  • Subscriber:消息的订阅者

从三种角色的描述中,大家也不难发现,消息的传递过程大体是这样:

  • Publisher产生消息并将消息传递到Broker;
  • Broker将消息传输给不同的Subscriber;
  • Subscriber再订阅响应的消息。

值得注意的是发布和订阅还有一个概念叫做Topic,也就是主题,这个又是个啥?

在上面描述中,大家不知道有没有疑问,发布者将消息发给Broker,Broker又向外分发,Broker知道怎么发吗?无脑的群发吗?订阅者也无脑的接收所有的消息吗?

如果真的是这样,那不乱套了!

所以Topic就来拯救了!

如果你不知道怎么理解主题,那你就把主题看作是一个通道或者你就把其中一个主题看成我的公众号【网络技术联盟站】,在看文章的你,微信中关注的公众号肯定是有限的,你作为订阅者,我是作者,所以相当于是消息的发布者,而微信服务器相当于是Broker,我觉得这个概念你是理解的吧?

那么想象一下,你是不是订阅了所有的公众号?或者说每个公众号发布的消息你都能看到?再或者说微信服务器有没有将所有的公众号消息都推给你?

这一切的一切,答案是不是都是:“否”?

那么首先要明确的是微信公众号的推送方式就类似于“发布-订阅”的模式,那么主题怎么理解呢?

你可以就理解为我的公众号【网络技术联盟站】,只是在微信的领域,主题可能是【科技/信息技术/网络技术联盟站】。

在MQTT中主题也是通过“/”去连接的,它是消息的通道,消息的发布者会朝某个主题中发布消息,订阅这个主题的订阅者都能收到这个消息。

以上就是MQTT消息传输过程的简单解释,下面我们介绍一下MQTT的QoS。

什么是服务质量 (QoS)?

服务质量(QoS) 级别是消息发送者和消息接收者之间的协议,它定义了特定消息的传递保证。

MQTT 中有 3 个 QoS 级别:

  • QoS 0
  • QoS 1
  • QoS 2

有人对特定消息的传递保证这个短句不太理解,什么叫做传递保证

我举个例子哈,比如你去某某公司找个人,到这家公司后你肯定首先见到的是前台工作人员,这个时候你跟前台人员说话,你说“美女,你好,我找你们公司王工,请帮我喊一下!”

这个时候,可能公司太忙,美女前台没有听到你的消息,你就在那一直问,或者你就问一次,也不管结果了。

还有一种情况就是,前台听到了,她去找你要找的王工,可能王工去开会了,没在工位,这个时候前台也有两种情况,一种就是来回来回找,知道找到,一种就是找过一次,不管找没找到也不找了。

那么理解上面的话,我再讲QoS,你就很好理解了。

MQTT中的QoS

在 MQTT 中谈 QoS 时,需要考虑消息传递的两个方面:

  • 消息从发布客户端(Publisher)传递到代理(Broker)。
  • 从代理(Broker)到订阅客户端(Subscriber)的消息传递。

我们将分别查看消息传递的两个方面,因为两者之间存在细微差别。将消息发布到代理的客户端()在向代理(前台)发送消息时定义了消息的 QoS 级别(重复喊的次数),代理使用每个订阅客户端在订阅过程中定义的 QoS 级别将此消息传输到订阅客户端,这个时候,如果订阅客户端定义的 QoS 低于发布客户端,则代理会以较低的服务质量发送消息。

最后一句话怎么理解,比如你向前台喊一次,正常情况下,前台会帮你去王工工位上喊一次,或者不喊,这个理解吧,这个是不是就是【代理会以较低的服务质量发送消息】的理解,或者你向前台喊两次,前台可以帮你喊一次、喊两次(最多)、甚至不喊。

如果你能理解以上我举的例子,下面你再去了解各个级别的QoS会非常好理解!

此处是不是先给文章点个赞,老铁!

QoS 0

最多一次

QoS 0 是尽最大努力传递,不保证消息的传递。当 MQTT 客户端以 QoS 1 发布时,MQTT 代理不确认收到,并且消息不被发送者存储和重新发送,QoS 0 通常被称为“即发即弃”,提供与底层 TCP 协议相同的保证。

QoS 1

至少一次

QoS 1 保证一条消息至少一次传递给接收方,MQTT 代理将使用 PUBACK 确认消息。MQTT 客户端将存储消息,直到它收到来自代理的 PUBACK,MQTT 客户端可能会多次传递消息,直到收到代理的确认。

发送方使用每个数据包中的数据包标识符将 PUBLISH 数据包与相应的 PUBACK 数据包匹配,如果发送方在合理的时间内没有收到 PUBACK 数据包,则发送方重新发送 PUBLISH 数据包。

QoS 2

仅一次

QoS 2 是 MQTT 中最高级别的服务,此级别保证每条消息仅由预期的收件人接收一次,QoS 2 是最安全最慢的服务质量级别,该保证由发送方和接收方之间的至少两个请求/响应流(四次握手)提供,发送方和接收方使用原始 PUBLISH 消息的数据包标识符来协调消息的传递。

当接收方从发送方获得 QoS 2 PUBLISH 数据包时,它会相应地处理发布消息,并使用确认 PUBLISH 数据包的PUBREC数据包回复发送方。如果发送方没有从接收方收到 PUBREC 数据包,它会再次发送带有重复 (DUP) 标志的 PUBLISH 数据包,直到收到确认。

总结

近年来,物联网的发展,使得MQTT协议变得越来越香,而MQTT中的服务质量也就是QoS是MQTT中比较重要的概念,当你使用的时候,发现你明明就想发送一条消息,但是日志显示你发了多条,难道你是真的发了多条吗?非也,可以好好检查一下你设置的QoS,然后不理解的话可以多看看本文,本文详细的介绍了QoS的三个级别,希望能给您带来收获!

如果您觉得本文对您认识MQTT的QoS概念有所帮助,请记得点赞收藏,如果有任何疑问,欢迎在下发评论区与我讨论,谢谢阅读!

相关实践学习
快速体验阿里云云消息队列RocketMQ版
本实验将带您快速体验使用云消息队列RocketMQ版Serverless系列实例进行获取接入点、创建Topic、创建订阅组、收发消息、查看消息轨迹和仪表盘。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
目录
相关文章
|
3月前
|
消息中间件 安全 物联网
海量接入、毫秒响应:易易互联基于 Apache RocketMQ + MQTT 构筑高可用物联网消息中枢
易易互联科技有限公司是吉利集团旗下专注于换电生态的全资子公司,致力于打造安全、便捷、便宜的智能换电网络。公司依托吉利GBRC换电平台,基于电池共享与车辆全生命周期运营,已布局超470座换电站,覆盖40多个城市,计划2027年达2000座。面对海量设备高并发连接、高实时性要求及数据洪峰挑战,易易互联采用阿里云MQTT与RocketMQ构建高效物联网通信架构,实现稳定接入、低延迟通信与弹性处理,全面支撑其全国换电网络规模化运营与智能化升级。
258 1
海量接入、毫秒响应:易易互联基于 Apache RocketMQ + MQTT 构筑高可用物联网消息中枢
|
3月前
|
数据采集 传感器 监控
Modbus 与 MQTT 协议兼容:MyEMS 的泛在能源数据采集技术实现
MyEMS深度融合Modbus与MQTT协议,破解能源数据采集中协议碎片化、网络异构、数据孤岛等难题。通过Modbus接入95%以上工业设备,实现现场数据精准“拉取”;依托MQTT构建高效物联网传输通道,支持多源数据主动“推送”与云端集成。边缘侧采集规整,中心侧汇聚分析,形成统一、可靠、低延迟的数据流。该架构兼具高兼容性、强扩展性与低运维成本,广泛应用于工业园区、商业楼宇及集团型企业,支撑实时监控、AI分析与跨系统融合,打造泛在互联的能源数据底座,助力企业实现全面智慧能源管理。
270 6
|
9月前
|
传感器 人工智能 物联网
健康监测设备的技术革命:AI+物联网如何让你随时掌握健康数据?
健康监测设备的技术革命:AI+物联网如何让你随时掌握健康数据?
1101 19
|
7月前
|
物联网
(手把手)在华为云、阿里云搭建自己的物联网MQTT消息服务器,免费IOT平台
本文介绍如何在阿里云搭建自己的物联网MQTT消息服务器,并使用 “MQTT客户端调试工具”模拟MQTT设备,接入平台进行消息收发。
2472 42
|
7月前
|
物联网
如何在腾讯云等平台搭建自己的物联网MQTT服务器Broker
物联网技术及MQTT协议被广泛应用于各种场景。本文介绍物联网MQTT服务助手下载,如何搭建自己的物联网平台,并使用 “MQTT客户端调试工具”模拟MQTT设备,接入平台进行消息收发。
566 37
|
9月前
|
监控 物联网 网络性能优化
【杂谈】-MQTT与HTTP在物联网中的比较:为什么MQTT是更好的选择
通过上述分析,可以看出MQTT在物联网应用中的确是更好的选择。其高效的通信模型、低带宽消耗、稳定的连接保持机制以及可靠的消息质量保证,使其在各种物联网场景中都能表现出色。开发者在设计和实现物联网系统时,应优先考虑采用MQTT协议,以充分发挥其在资源受限环境下的优势,提升系统的整体性能和可靠性。
1395 26
|
8月前
|
SQL 大数据 数据库
RocketMQ实战—1.订单系统面临的技术挑战
本文详细分析了一个订单系统的设计与技术挑战。首先,介绍了订单系统的整体架构、业务流程及负载情况,包括电商购物流程、核心和非核心业务流程,以及真实生产中的负载压力。接着,探讨了系统面临的主要技术问题:支付后发券、发红包等操作导致性能下降;退款流程复杂且易失败;与第三方系统耦合带来的不稳定;大数据团队直接查询数据库影响性能;秒杀活动时数据库压力剧增等。最后,通过放大100倍压力的方法,梳理了高并发下的技术挑战,如核心链路优化、后台线程补偿机制、第三方系统解耦、数据获取方式改进等,为订单系统的优化提供了全面的参考。
RocketMQ实战—1.订单系统面临的技术挑战
|
安全 物联网 物联网安全
揭秘区块链技术在物联网(IoT)安全中的革新应用
揭秘区块链技术在物联网(IoT)安全中的革新应用
|
12月前
|
存储 安全 物联网
未来已来:区块链技术在物联网与虚拟现实中的应用
随着科技的不断进步,新兴技术如区块链、物联网(IoT)和虚拟现实(VR)正在逐渐改变我们的生活和工作方式。本文将探讨这些技术的发展趋势和应用场景,以及它们如何相互融合,为我们带来更便捷、安全和沉浸式的体验。
|
12月前
|
供应链 监控 数据可视化
物联网技术在物流与供应链管理中的应用与挑战
本文探讨了物联网技术在物流与供应链管理中的应用,通过实时追踪、信息共享、智能化决策等手段,大幅提升了管理效率和智能化水平。特别介绍了板栗看板作为专业可视化工具,在数据监控、分析及协同作业中的重要作用。未来,随着技术的进一步发展,物流与供应链管理将更加智能高效,但也面临数据安全、标准化等挑战。

相关产品

  • 物联网平台