当前位置: 首页 > article >正文

保姆级教程:用Python和Paho-MQTT库5分钟搭建你的第一个物联网通信Demo

5分钟实战用PythonPaho-MQTT构建物联网通信原型在智能家居设备突然向你手机推送报警消息时在共享单车锁车后立即完成计费时背后都是MQTT协议在高效运作。作为物联网领域的HTTP协议MQTT凭借其轻量级和发布/订阅模式已经成为连接物理世界与数字世界的隐形桥梁。今天我们将用Python和Paho-MQTT库带你快速搭建一个可实际运行的通信原型——不需要硬件设备你的笔记本电脑就是物联网终端。1. 环境准备三行命令搭建开发环境打开终端我们首先需要配置Python环境。推荐使用Python 3.6版本这是大多数物联网云平台SDK的兼容基准线。安装依赖只需执行pip install paho-mqtt pip install python-dotenv # 用于管理敏感配置为什么选择Paho-MQTT这个由Eclipse基金会维护的库不仅是MQTT协议参考实现更提供了完善的异步通信机制。它的API设计非常直观比如on_connect回调函数会在连接建立时自动触发。创建项目目录结构/mqtt_demo ├── publisher.py # 消息发布端 ├── subscriber.py # 消息订阅端 └── .env # 存放Broker配置2. 连接公共MQTT Broker我们使用EMQX提供的免费公共Broker作为测试服务器。在.env文件中配置连接参数MQTT_BROKERbroker.emqx.io MQTT_PORT1883 MQTT_TOPICmyhome/livingroom/temperature在Python中读取配置的最佳实践是使用python-dotenvfrom dotenv import load_dotenv import os load_dotenv() broker os.getenv(MQTT_BROKER) port int(os.getenv(MQTT_PORT)) topic os.getenv(MQTT_TOPIC)注意生产环境务必使用加密连接(端口8883)本文为演示使用未加密的1883端口3. 构建消息订阅者订阅者是物联网系统中的数据接收方。创建subscriber.py文件核心代码如下import paho.mqtt.client as mqtt def on_connect(client, userdata, flags, rc): print(fConnected with result code {rc}) client.subscribe(topic, qos1) # 设置QoS级别为1 def on_message(client, userdata, msg): print(fReceived {msg.payload.decode()} from {msg.topic}) client mqtt.Client(client_idsubscriber-001) client.on_connect on_connect client.on_message on_message client.connect(broker, port) client.loop_forever() # 保持长连接关键参数解析client_id每个客户端必须唯一相当于设备IDqos1确保消息至少送达一次loop_forever()维持网络连接心跳4. 开发消息发布者发布者模拟物联网设备发送数据。publisher.py的核心逻辑import time import json from random import uniform client mqtt.Client(client_idpublisher-001) client.connect(broker, port) client.loop_start() # 使用后台线程处理网络流量 try: while True: temperature round(uniform(18.0, 28.0), 1) payload json.dumps({ ts: int(time.time()), value: temperature, unit: °C }) client.publish(topic, payload, qos1) print(fPublished {payload}) time.sleep(5) except KeyboardInterrupt: client.disconnect()这个发布者每5秒发送一次模拟的温度数据使用JSON格式封装。在实际项目中这里可能是真实的传感器读数。5. 高级功能扩展5.1 遗嘱消息配置设备意外离线时通知系统client.will_set( topicdevice/status, payloadpublisher-001 offline, qos1, retainTrue )5.2 消息保留与持久会话# 发布保留消息 client.publish(topic, payload, retainTrue) # 连接时恢复会话 client.connect(broker, port, keepalive60, clean_sessionFalse)5.3 多主题订阅与通配符# 订阅多个主题 client.subscribe([ (myhome//temperature, 1), (myhome/#, 1) # 多级通配符 ])6. 实战测试与调试先启动订阅者python subscriber.py再运行发布者python publisher.py观察终端输出应该能看到类似Published {ts: 1620000000, value: 22.5, unit: °C} Received {ts: 1620000000, value: 22.5, unit: °C} from myhome/livingroom/temperature常见问题排查连接超时检查防火墙是否阻止了1883端口QoS不生效确保订阅和发布使用相同的QoS级别消息乱码payload建议统一使用UTF-8编码7. 生产环境建议当Demo验证通过后升级到生产环境需要考虑安全加固使用TLS加密连接启用用户名/密码认证实现ACL访问控制性能优化# 使用异步客户端 from paho.mqtt.client import Client client Client(transportwebsockets) # 适合Web应用云端集成阿里云IoTa1W4mJ9XXXX.iot-as-mqtt.cn-shanghai.aliyuncs.comAWS IoTyour-endpoint.amazonaws.com客户端管理# 获取所有连接客户端 client._client_id # 当前客户端ID在智能家居项目中我习惯用设备序列号作为client_id这样当设备重复连接时Broker能自动识别。曾经有个bug是因为client_id冲突导致消息混乱——两个温湿度传感器用了相同的ID结果数据完全错乱。这个教训让我深刻理解了client_id唯一性的重要。

相关文章:

保姆级教程:用Python和Paho-MQTT库5分钟搭建你的第一个物联网通信Demo

5分钟实战:用PythonPaho-MQTT构建物联网通信原型 在智能家居设备突然向你手机推送报警消息时,在共享单车锁车后立即完成计费时,背后都是MQTT协议在高效运作。作为物联网领域的"HTTP协议",MQTT凭借其轻量级和发布/订阅模…...

GCC扩展语法在嵌入式开发中的高效应用

1. GCC扩展语法深度解析在嵌入式开发领域,GCC编译器因其强大的功能和灵活的扩展特性而广受欢迎。作为一名长期从事嵌入式系统开发的工程师,我发现掌握GCC的扩展语法能显著提升代码效率和可维护性。今天我将分享几个在实际项目中特别实用的GCC扩展语法特性…...

颠覆式网盘直连提取革新:ctfileGet让高速下载成为现实

颠覆式网盘直连提取革新:ctfileGet让高速下载成为现实 【免费下载链接】ctfileGet 获取城通网盘一次性直连地址 项目地址: https://gitcode.com/gh_mirrors/ct/ctfileGet 副标题:突破下载限速困境,3步实现城通网盘直链高效提取 ctfil…...

IM023-将PDF文件导出jpg图片到PDF所在目录下

批量将pdf文档每页导出为jpg图片 比如A文件夹下有B、C、D、E....等文件夹,每个文件夹下都有一定的pdf文件,将程序放在A文件夹下,运行程序后会将B、C、D、E....等文件夹下每个pdf文件分别导出为jpg图片,导出的jpg图片命名方式为&am…...

喜马拉雅音频下载器终极指南:快速批量下载VIP有声小说与付费专辑

喜马拉雅音频下载器终极指南:快速批量下载VIP有声小说与付费专辑 【免费下载链接】xmly-downloader-qt5 喜马拉雅FM专辑下载器. 支持VIP与付费专辑. 使用GoQt5编写(Not Qt Binding). 项目地址: https://gitcode.com/gh_mirrors/xm/xmly-downloader-qt5 你是否…...

从产品到生态:观远数据的一站式智能分析平台之路

开篇:客户现场的真实发问 上个月在华东某快消头部企业的CIO圆桌会上,负责数字化转型的副总裁问了我一个很尖锐的问题: “你们BI厂商总说一站式,但我前几年买的BI工具,最后要么数据接不上要额外买数仓工具,要…...

直接上干货,这个方案最香的就是省掉PLC还能玩转两台变频器。实测施耐德ATV312配MCGS屏的RTU通讯稳得一批,咱们先从最关键的接线开整

mcgs rtu方式通讯两台施耐德ATV312变频器示例 ,通讯实现触摸屏控制监控变频器,中间不需要plc,功能多而且使用方便,关键还节约成本。 所需硬件:施耐德atv312变频器,mcgs触摸屏(没屏也可,电脑在线…...

020驱动模型与sysfs:当你的驱动需要“见人”时

最近在调试一个车载CAN设备时遇到个怪现象:驱动能正常收发数据,但每次系统休眠唤醒后设备就丢了。查了半天发现,原来设备电源管理回调根本没被调用。老张路过我工位瞟了一眼,扔下一句话:“你这驱动没‘上户口’吧&…...

革新性植物大战僵尸辅助工具:PVZ Toolkit全方位功能解析

革新性植物大战僵尸辅助工具:PVZ Toolkit全方位功能解析 【免费下载链接】pvztoolkit 植物大战僵尸 PC 版综合修改器 项目地址: https://gitcode.com/gh_mirrors/pv/pvztoolkit PVZ Toolkit是一款专为《植物大战僵尸》PC版设计的革新性辅助工具,集…...

019驱动调试与性能优化:printk、动态调试、ftrace、perf工具链

从一次诡异的I2C超时说起 上周排查一个车载IVI系统的触摸屏失灵问题,现象是冷启动后触摸完全无响应,但系统日志里没有任何错误信息。用逻辑分析仪抓I2C波形发现,主机发了START信号后SCL就被拉低了——典型的从设备忙状态。但驱动代码里对应的…...

猫抓资源嗅探扩展完整配置指南:从零开始掌握网页资源捕获

猫抓资源嗅探扩展完整配置指南:从零开始掌握网页资源捕获 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 还在为无法下载网页视频而烦恼…...

OpenClaw异常处理指南:千问3.5-35B-A3B-FP8任务失败的8种排查方法

OpenClaw异常处理指南:千问3.5-35B-A3B-FP8任务失败的8种排查方法 1. 当OpenClaw遇上千问3.5:我的踩坑起点 上周三凌晨2点,我正试图用OpenClaw自动整理一批会议录音转写的文本。这个任务需要先调用千问3.5-35B-A3B-FP8模型提取关键信息&…...

3dsconv:任天堂3DS游戏格式转换的全流程解决方案

3dsconv:任天堂3DS游戏格式转换的全流程解决方案 【免费下载链接】3dsconv Python script to convert Nintendo 3DS CCI (".cci", ".3ds") files to the CIA format 项目地址: https://gitcode.com/gh_mirrors/3d/3dsconv 问题导入&…...

Boost电路与SMC滑模控制策略:文章复现及性能优化探讨

boost电路,smc滑模控制,文章复现Boost电路在电力电子里算是老熟人了,但真要玩转它的闭环控制可不容易。最近在复现一篇用滑模控制(SMC)搞Boost电路的论文,实测发现这货对付负载突变确实有两把刷子。今天咱们…...

VS Code官宣:全面支持Rust!

当"宇宙第一编辑器"遇上"内存安全的叛逆少年",这场联姻比想象中更甜~最近微软悄悄放了个大招:VSCode 要深度集成 rust-analyzer 了! 🎉 什么意思呢?以前你用 VSCode 写 Rust&#xff0…...

DENSO电装机器人软件授权序列号 wincaps3软件授权和软件安装包及软件手册

DENSO电装机器人软件授权序列号 wincaps3软件授权和软件安装包及软件手册 永久使用序列号 给机器人工程师的WinCaps3安装避坑指南 最近在调试DENSO机械臂的时候,发现不少同行在WinCaps3的安装和授权环节翻车。今天就结合自己的踩坑经验,聊聊怎么搞定这个…...

改进蚁群算法结合Dijkstra与MAKLINK图理论实现二维空间最优路径规划

【改进蚁群算法】/蚁群算法/Dijkstra算法/遗传算法/人工势场法实现二维/三维空间路径规划 本程序为改进蚁群算法Dijkstra算法MAKLINK图理论实现的二维空间路径规划 算法实现: 1)基于MAKLINK图理论生成地图,并对可行点进行划分; 2…...

AI赋能前端开发:让快马平台智能生成仪表盘页面架构与代码

最近在做一个数据可视化项目时,遇到了一个典型的前端开发需求:需要快速搭建一个专业级的仪表盘页面。这个页面需要包含数据概览卡片、图表展示区和用户留言列表三大核心模块。作为一个独立开发者,既要考虑UI美观度,又要兼顾代码质…...

深入理解 C# 架构思维:继承的界限、多态的解耦与属性的封装

C#学习笔记面向对象编程:继承什么是继承继承的语法方法的重写构造函数的重载与 base 关键字动物世界完整实例踩坑汇总面向对象编程:多态多态的实现步骤踩坑汇总面向对象编程:封装核心套路:私有字段 公开属性代码实例踩坑汇总面向…...

新手福音:用claude code和快马平台开启你的Python编程第一课

最近在帮朋友入门Python编程时,发现很多新手都会遇到类似的问题:看教程时觉得简单,但自己动手写代码就无从下手。经过几次尝试,我发现用InsCode(快马)平台结合claude code生成的教学项目,能很好地解决这个痛点。下面分…...

科技信息最前沿——TurboQuant:以极致压缩重新定义人工智能效率

谷歌TurboQuant技术突破:高效压缩AI内存需求谷歌TurboQuant技术通过创新的免训练压缩方法,有效解决了大语言模型面临的内存瓶颈问题。该技术采用两阶段压缩方案:PolarQuant极坐标量化和QJL误差修正,在不损失精度的前提下实现显著优…...

体验ai辅助开发:在快马平台与ai协作构建智能任务管理应用

最近尝试用AI辅助开发了一个任务管理应用,整个过程就像有个经验丰富的编程伙伴在旁边随时提供建议。在InsCode(快马)平台上,这种协作体验特别流畅,分享下具体实现过程: 初始框架搭建 输入"创建一个Vue3任务列表应用&#xff…...

(97页PPT)DG华为流程管理全景从定位到优化的高效增长策略(附下载方式)

篇幅所限,本文只提供部分资料内容,完整资料请看下面链接 https://download.csdn.net/download/AI_data_cloud/89624196 资料解读:《(97页PPT)DG华为流程管理全景从定位到优化的高效增长策略》 详细资料请看本解读文章…...

GEE数据集:全球6400万地点数据免费开放(世界实体的点):商家、学校、医院、宗教组织、地标、山峰等

数据描述 Overture Maps Places 主题包含超过 6,400 万个现实世界实体的点表示形式:商家、学校、医院、宗教组织、地标、山峰等等。 每个地点记录都包含位置坐标、名称、类别、联系信息(网站、社交媒体、电子邮件地址、电话号码)、品牌信息、…...

典型的TCP客户端单次事务处理VI 通过已建立的TCP连接,发送一段数据(命令/字符串),等待设备响应后读取指定字节数的返回数据

这个VI程序框图详细解析(LabVIEW TCP通信事务VI)这是一个典型的TCP客户端单次事务处理VI(常命名为“TCP Send & Receive.vi”或“TCP通信子VI”)。 它的核心功能是:通过已建立的TCP连接,发送一段数据&a…...

响应 (接上文)

在我们前⾯的代码例⼦中&#xff0c;都已经设置了响应数据,Http响应结果可以是数据,也可以是静态⻚⾯,也可 以针对响应设置状态码,Header信息等.返回静态⻚⾯创建前端⻚⾯index.html(注意路径)html代码如下:<!DOCTYPE html> <html lang"en"> <head>…...

【27】软考软件设计师——数据流图(DFD)补全题满分精讲|下午15分大题深度拆解

摘要:本文是《软件设计师50讲通关|从零基础到工程师职称》专栏第27篇,深度精讲下午案例题第1道必考大题:数据流图(DFD)补全,该题单题分值高达12 ~ 15分,是整张试卷最稳的保底得分大题。我结合多年备考复盘与真题阅卷规则,超详细拆解DFD四大核心元素标准定义、机考绘图…...

突破暗黑破坏神2单机限制:PlugY全方位增强工具深度指南

突破暗黑破坏神2单机限制&#xff1a;PlugY全方位增强工具深度指南 【免费下载链接】PlugY PlugY, The Survival Kit - Plug-in for Diablo II Lord of Destruction 项目地址: https://gitcode.com/gh_mirrors/pl/PlugY 暗黑破坏神2作为ARPG游戏的经典之作&#xff0c;其…...

消息队列5-RabbitMQ的高级特性和MQ的应用问题与解决方案-事务、消息分发的应用、幂等性保证、顺序性保证、消息积压的解决

文章目录一. 事务1. 模版开启事务功能2. 配置事务管理器3. 声明队列4. 生产者5. 运行图二. 消息分发1. 限流(1) yml配置文件(2) 声明队列与交换机及绑定关系(3) 生产者(4) 消费者(5) 运行图2. 负载均衡(1) yml配置(2) 消费者代码(3) 运行图三. MQ的幂等性保证1. MQ中存在的问题…...

3步解锁高效采集:让小红书素材获取效率提升80%的XHS-Downloader开源工具

3步解锁高效采集&#xff1a;让小红书素材获取效率提升80%的XHS-Downloader开源工具 【免费下载链接】XHS-Downloader 小红书&#xff08;XiaoHongShu、RedNote&#xff09;链接提取/作品采集工具&#xff1a;提取账号发布、收藏、点赞、专辑作品链接&#xff1b;提取搜索结果作…...