Python系列 - MQTT协议

Python系列 - MQTT协议

资源连接

MQTT的介绍和应用场景的示例说明

一、什么是MQTT

百度关于MQTT的介绍如下:
MQTT(消息队列遥测传输)是ISO 标准(ISO/IEC PRF 20922)下基于发布订阅范式的消息协议。它工作在 TCP/IP协议之上,是为硬件性能低下的远程设备以及网络状况糟糕的情况下而设计的发布/订阅型消息协议,
MQTT是一个基于客户端-服务器的消息发布/订阅传输协议。MQTT协议是轻量、简单、开放和易于实现的。
MQTT适用范围非常广泛。在很多情况下,包括受限的环境中,如:机器与机器(M2M)通信和物联网(IoT)。其次,通过卫星链路通信传感器、偶尔拨号的医疗设备、智能家居、及一些小型化设备中已广泛使用。

二、 MQTT的特点

MQTT协议是为大量计算能力有限,且工作在低带宽、不可靠的网络的远程传感器和控制设备通讯而设计的协议,因此它具有以下主要的几项特性:

  • 轻量级和高效‌:MQTT协议的客户端代码量小,对系统资源的需求较低。小型传输,开销很小(固定长度的头部是 2 字节),协议交换最小化,以降低网络流量,提高了传输效率。

  • 支持双向通信‌:MQTT协议支持设备到云端以及云端到设备之间的消息传递,使得向大量设备广播消息变得相对简单。

  • 数据传输可靠‌:MQTT支持多种消息服务质量等级(QoS),确保数据按需可靠传输。QoS 0表示最多发送一次,QoS 1表示至少发送一次,QoS 2表示确保消息只有一次到达。

  • 支持离线消息‌:通过保留消息和持久会话,MQTT支持设备离线时的消息保存和转发。

  • 简单易用‌:MQTT协议使用 TCP/IP 提供网络连接,结构简单,易于实现和维护,适合低带宽和不可靠的网络环境。

  • 发布/订阅模式‌:MQTT基于发布/订阅模式,消息通过主题进行分类。客户端可以订阅一个或多个主题,发布者发送消息到特定的主题,所有订阅该主题的客户端都将接收到这些消息,通过提供一对多的消息发布,解除应用程序耦合。

三、 MQTT的工作流程

MQTT的信息基于发布和订阅模式,通过主题进行相应的分类,基于发布订阅模式及其代理服务器的理解示意图:
在这里插入图片描述基于MQTT的发布订阅模式下,其工作流程如下:
在这里插入图片描述其中,MQTT传输的内容包括两个部分:

  • 主题(Topic):主题可以理解为信息的主题,订阅者订阅(Subscribe)后,就会收到该主题的内容(payload);
  • 负载(payload):可以理解为信息的内容,是指订阅的具体要使用的内容。

四、MQTT的工作模式

MQTT提供三种工作模式来保证数据的传输,三种工作模式和应用场景介绍如下:

  • 至多一次:丢掉记录无所谓的场景;
  • 至少一次:确保信息到达,但信息可能会重复;
  • 只有一次:确保消息到达一次(小型传输,开销小)

五、MQTT的应用场景

MQTT的在如下三种场景下具有明显的优势:

  • 带宽低
  • 网络延迟高
  • 网络通信不稳定

由于MQTT在三大场景下的优势,使得MQTT特别适合物联网(IoT)和类似场景:

  • 物联网(IoT)‌:MQTT是物联网领域中最典型的应用之一。在物联网中,大量的设备和传感器需要进行数据的收集、监控和控制。MQTT协议的特性使其成为物联网通信的理想选择。例如,智能家居系统可以使用MQTT来监控和控制家中的各种设备,如智能灯泡、恒温器等。

  • 工业控制和远程监测‌:MQTT在工业控制和远程监测领域也有广泛的应用。它的可靠性和低带宽消耗特性使其非常适合在工业环境中进行实时数据传输和远程控制。例如,工业设备监控可以通过MQTT实时将数据上传至云端或控制中心,用于生产线状态监控、设备维护预警等。

  • 即时通讯和实时数据传输‌:MQTT的低延迟和可靠性使其成为即时通讯和实时数据传输的理想选择。例如,聊天室和实时消息推送应用可以使用MQTT来实现用户之间的实时通讯。此外,MQTT还适用于需要实时数据传输的应用,如实时股票行情、天气数据等。

  • 实时位置追踪‌:MQTT可以用于实时位置追踪应用。移动设备可以发布自己的位置信息,其他用户或系统可以订阅这些信息来获取实时位置数据。这对于车队管理、物流跟踪等应用非常有用。

  • 其他场景‌:MQTT还应用于传感器数据传输、数据传输和同步、远程监控和控制系统等领域。例如,气象站、环境监测等领域可以使用MQTT进行传感器数据的采集和传输;跨平台数据同步、数据备份等场景也可以利用MQTT实现数据的实时同步。

六、python代码实现订阅

> #!/usr/bin/env python 
> # 基于Pika实现对MQTT的通信
> import pika 
> import sys 
> import json
> > channel = conn.channel()
> 
> channel.exchange_declare(exchange='test.topic',exchange_type='topic',durable=True) #订阅的topic
> 
> result = channel.queue_declare(queue='2570',
> durable=True,auto_delete=False,exclusive=False) queue_name =
> result.method.queue
> 
> channel.queue_bind(
>         exchange='test.topic', queue=queue_name, routing_key='order.PM02.2570')
> 
> print(' [*] Waiting for logs. To exit press CTRL+C')
> 
> 
> def callback(ch, method, properties, body):
>     #print(" [x] %r:%r" % (method.routing_key, body))
>     j_text = json.loads(body)
>     print(j_text)
>     #j_Order = j_text['maintOrder']
>     #print(j_Order)
>     j_PM = j_text['pmType']
>     print(j_PM)> # 执行订阅程序
> channel.basic_consume(
>     queue=queue_name, on_message_callback=callback, auto_ack=True) try:
>     channel.start_consuming() except Exception as e :
>     print(e)
>     channel.start_consuming()

参考:
MQTT
MQTT协议
mqtt的应用场景有哪些

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/481983.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

winform跨线程更新界面

1、报错代码 下面的代码中的this.Text指的是一个winform的窗体,开启Task执行下面的代码以后直接报错,提示线程间操作无效,这是因为在WinForms应用程序中,UI元素(如控件)通常只能在创建它们的线程&#xff…

Mybatis:CRUD数据操作之多条件查询及动态SQL

Mybatis基础环境准备请看:Mybatis基础环境准备 本篇讲解Mybati数据CRUD数据操作之多条件查询 1,编写接口方法 在 com.itheima.mapper 包写创建名为 BrandMapper 的接口。在 BrandMapper 接口中定义多条件查询的方法。 而该功能有三个参数,…

音视频技术扫盲之预测编码的基本原理探究

预测编码是一种数据压缩技术,广泛应用于图像、视频和音频编码等领域。其基本原理是利用数据的相关性,通过对当前数据的预测和实际值与预测值之间的差值进行编码,从而实现数据压缩的目的。 一、预测编码的基本概念 预测编码主要包括预测器和…

5. langgraph实现高级RAG (Adaptive RAG)

1. 数据准备 from langchain.text_splitter import RecursiveCharacterTextSplitter from langchain_community.document_loaders import WebBaseLoader from langchain_community.vectorstores import Chromaurls ["https://lilianweng.github.io/posts/2023-06-23-age…

自动化配置

自动化配置共享目录 nfs:共享某个目录,共享给哪些客户端,rw(读写)——rwx(给目录权限设置),ro(只读) 写脚本 1、装包 可以调用仓库之前装包的脚本 &#x…

AtomicIntegerFieldUpdater能否降低内存

1. 代码如下: import java.util.LinkedList; import java.util.List; import java.util.concurrent.atomic.AtomicInteger;public class AtomicIntegerTest {final AtomicInteger startPosition new AtomicInteger(0);final AtomicInteger wrotePosition new Atom…

微服务即时通讯系统的实现(服务端)----(3)

目录 1. 消息存储子服务的实现1.1 功能设计1.2 模块划分1.3 模块功能示意图1.4 数据管理1.4.1 数据库消息管理1.4.2 ES文本消息管理 1.5 接口的实现1.5.1 消息存储子服务所用到的protobuf接口实现1.5.2 最近N条消息获取接口实现1.5.3 指定时间段消息搜索接口实现1.5.4 关键字消…

数据湖的概念(包含数据中台、数据湖、数据仓库、数据集市的区别)--了解数据湖,这一篇就够了

文章目录 一、数据湖概念1、企业对数据的困扰2、什么是数据湖3、数据中台、数据湖、数据仓库、数据集市的区别 网上看了好多有关数据湖的帖子,还有数据中台、数据湖、数据仓库、数据集市的区别的帖子,发现帖子写的都很多,而且专业名词很多&am…

202页MES项目需求方案深入解读,学习MES系统设计规划

202页MES项目需求方案深入解读,学习MES系统设计规划 MES项目需求方案旨在实现制造执行、效率提升、精细化管理等多个方面的功能。整体结构分为七大部分,包括制造执行、效率、精细化、品质在线、设备、用户思想和数据互联。制造执行部分关注订单、品质数据…

基础(函数、枚举)错题汇总

枚举默认从0开始,指定后会按顺序赋值 而这个枚举变量X,如果在全局(函数外部)定义,那默认为0,如果在函数内部(局部变量),那就是随机值,必须初始化。 枚举变量…

互联网基础

TCP/IP协议(协议组) 分层名称TCP/IP协议应用层HTTP,FTP,mDNS,WebSocket,OSC...传输层TCP,UDP网络层IP链路层(网络接口层)Ethernet,Wi-Fi... 链路层(网络接口层) 链路层的主要作用…

【Vue3】从零开始创建一个VUE项目

【Vue3】从零开始创建一个VUE项目 手动创建VUE项目附录 package.json文件报错处理: Failed to get response from https://registry.npmjs.org/vue-cli-version-marker 相关链接: 【VUE3】【Naive UI】<NCard> 标签 【VUE3】【Naive UI】&…

用MATLAB符号工具建立机器人的动力学模型

目录 介绍代码功能演示拉格朗日方法回顾求解符号表达式数值求解 介绍 开发机器人过程中经常需要用牛顿-拉格朗日法建立机器人的动力学模型,表示为二阶微分方程组。本文以一个二杆系统为例,介绍如何用MATLAB符号工具得到微分方程表达式,只需要…

基于Java Springboot在线点餐系统

一、作品包含 源码数据库设计文档万字PPT全套环境和工具资源部署教程 二、项目技术 前端技术:Html、Css、Js、Vue、Element-ui 数据库:MySQL 后端技术:Java、Spring Boot、MyBatis 三、运行环境 开发工具:IDEA/eclipse 数据…

QT实战--qt各种按钮实现

本篇介绍qt一些按钮的实现,包括正常按钮;带有下拉箭头的按钮的各种实现;按钮和箭头两部分分别响应;图片和按钮大小一致;图片和按钮大小不一致的处理;文字和图片位置的按钮 效果图如下: 详细实现…

服务熔断-熔断器设计

文章目录 服务为什么需要熔断熔断器设计思想熔断器代码实现 服务为什么需要熔断 对于服务端采用的保护机制为服务限流。 对于服务调用端是否存在保护机制? 假如要发布一个服务 B,而服务 B 又依赖服务 C,当一个服务 A 来调用服务 B 时&#x…

入门数据结构JAVADS——如何构建一棵简单二叉排序树

目录 前言 什么是二叉排序树 二叉排序树的特点 二叉排序树示意图 构建二叉排序树 插入元素 搜索元素 删除元素 完整代码 结尾 前言 在整个十一月,笔者因为一些原因停笔了,但马上迈入12月进而进入2025年,笔者决定不再偷懒了,继续更新以促进学习的积极性.闲话说到这,今天…

更多开源创新 挑战OpenAI-o1的模型出现和AI个体模拟突破

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

BUUCTF—Reverse—Java逆向解密(10)

程序员小张不小心弄丢了加密文件用的秘钥,已知还好小张曾经编写了一个秘钥验证算法,聪明的你能帮小张找到秘钥吗? 注意:得到的 flag 请包上 flag{} 提交 需要用专门的Java反编译软件:jd-gui 下载文件,发现是个class文…

Redis(4):主从复制

一、主从复制概述 主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器。前者称为主节点(master),后者称为从节点(slave);数据的复制是单向的,只能由主节点到从节点。   默认情况下,每台Redis…