通过物联网管理多台MQTT设备-基于米尔T527开发板
2024-05-10
2251
来源:米尔电子
本篇测评由电子工程世界的优秀测评者“JerryZhen”提供。
本文将介绍基于米尔电子MYD-LT527开发板的网关方案测试。
一、系统概述
基于米尔-全志 T527设计一个简易的物联网网关,该网关能够管理多台MQTT设备,通过MQTT协议对设备进行读写操作,同时提供HTTP接口,允许用户通过HTTP协议与网关进行交互,并对设备进行读写操作。
二、系统架构
网关服务:基于FastAPI框架构建的Web服务,提供HTTP接口。 MQTT客户端:负责与MQTT设备通信,管理设备连接、消息发布和订阅。 设备管理:维护一个设备列表,记录设备的基本信息和状态。 数据存储:使用内存或数据库存储设备数据,确保数据持久化。
三、组件设计
MQTT组件:
负责与MQTT broker建立连接。 订阅设备主题,接收设备发送的消息。 发布消息到设备,实现远程控制。
设备管理组件:
维护一个设备列表,记录设备的唯一标识符(如设备ID)、MQTT主题、连接状态等信息。 提供设备增删改查的方法。
HTTP组件:
基于FastAPI定义HTTP接口。 接收用户请求,调用MQTT组件和设备管理组件进行相应操作。 返回操作结果给用户。
四、接口设计
设备列表:
GET /devices:返回所有设备的列表。 POST /devices:添加新设备到网关。 DELETE /devices/{device_id}:从网关中删除指定设备。
设备详情:
GET /devices/{device_id}:返回指定设备的详细信息。
设备数据:
GET /devices/{device_id}/data:获取指定设备的最新数据。 POST /devices/{device_id}/data:发送数据到指定设备。
设备控制:
POST /devices/{device_id}/control:发送控制命令到指定设备。
五、数据结构设计
设备信息:
设备ID (device_id):唯一标识设备的字符串。 MQTT主题 (mqtt_topic):设备在MQTT broker上的主题。 连接状态 (connection_status):表示设备是否在线的布尔值。 其他设备属性(如名称、描述等)。
设备数据:
设备ID (device_id):关联设备信息的设备ID。 时间戳 (timestamp):数据发送或接收的时间。 数据内容 (data):设备发送或接收的具体数据,可以是JSON格式或其他格式。
六、安全性考虑
使用HTTPS协议提供安全的HTTP通信。 实现用户认证和授权机制,确保只有授权用户可以访问和操作设备。 对于敏感操作(如删除设备),要求用户进行二次确认或提供额外的安全措施。
七、部署与扩展
使用Docker容器化部署网关服务,便于管理和扩展。 根据需要,可以水平扩展网关实例以处理更多的设备连接和请求。
八、实现步骤
安装所需的Python库:fastapi, uvicorn, paho-mqtt等。 创建FastAPI应用并定义路由。 实现MQTT组件,包括与MQTT broker的连接、订阅、发布等功能。 实现设备管理组件,维护设备列表并提供增删改查的方法。 实现HTTP组件,调用MQTT组件和设备管理组件处理用户请求。 编写测试代码,验证网关的各项功能是否正常工作。 部署网关服务并监控其运行状态。
该设计方案仅仅是概述,具体实现细节可能需要根据实际需求和项目环境进行调整和优化。在实际开发中,还需要考虑异常处理、日志记录、性能优化等方面的问题。基于上述设计方案,以下是一个简化版的参考代码,展示了如何使用FastAPI和paho-mqtt库来创建一个物联网网关。需要注意,示例中不包含完整的错误处理、用户认证和授权机制,这些在实际生产环境中都是必不可少的。依赖的主要库版本:
fastapi==0.108.0
paho-mqtt==1.6.1
网关模拟代码gateway.py:
from fastapi import FastAPI, HTTPException, Body, status
from paho.mqtt.client import Client as MQTTClient
from typing import List, Dict, Any
import asyncio
import json
app = FastAPI()
mqtt_client = None
device_data = {}
subtopic="gateway/device/#"
# MQTT回调函数
def on_message(client, userdata, msg):
payload = msg.payload.decode()
topic = msg.topic
device_id = topic.split('/')[-1]
device_data[device_id] = payload
print(f"Received message from {device_id}: {payload}")
# MQTT连接和订阅
def mqtt_connect_and_subscribe(broker_url, broker_port):
global mqtt_client
mqtt_client = MQTTClient()
mqtt_client.on_message = on_message
mqtt_client.connect(broker_url, broker_port, 60)
mqtt_client.subscribe(subtopic)
mqtt_client.loop_start()
# MQTT发布消息
async def mqtt_publish(topic: str, message: str):
if mqtt_client is not None and mqtt_client.is_connected():
mqtt_client.publish(topic, message)
else:
print("MQTT client is not connected!")
# 设备管理:添加设备
@app.post("/devices/", status_code=status.HTTP_201_CREATED)
async def add_device(device_id: str):
device_data[device_id] = None
return {"message": f"Device {device_id} added"}
# 设备管理:获取设备列表
@app.get("/devices/")
async def get_devices():
return list(device_data.keys())
# 设备管理:获取设备数据
@app.get("/devices/{device_id}/data")
async def get_device_data(device_id: str):
if device_id not in device_data:
raise HTTPException(status_code=status.HTTP_404_NOT_FOUND, detail=f"Device {device_id} not found")
return device_data.get(device_id)
# 设备管理:发送数据到设备
@app.post("/devices/{device_id}/data")
async def send_data_to_device(device_id: str, data: Dict[str, Any] = Body(...)):
topic = f"devices/{device_id}"
message = json.dumps(data)
await mqtt_publish(topic, message)
return {"message": f"Data sent to {device_id}"}
# 设备控制:发送控制命令到设备
@app.post("/devices/{device_id}/control")
async def control_device(device_id: str, command: str):
topic = f"devices/device/{device_id}"
await mqtt_publish(topic, command)
return {"message": f"Control command sent to {device_id}"}
# FastAPI启动事件
@app.on_event("startup")
async def startup_event():
mqtt_connect_and_subscribe("127.0.0.1", 1883)
# FastAPI关闭事件
@app.on_event("shutdown")
async def shutdown_event():
if mqtt_client is not None:
mqtt_client.loop_stop()
mqtt_client.disconnect()
# 运行FastAPI应用
if __name__ == "__main__":
import uvicorn
uvicorn.run(app, host="127.0.0.1", port=8000)设备1模拟代码 dev1.py:
import paho.mqtt.client as mqtt
# 连接成功回调
def on_connect(client, userdata, flags, rc):
print('Connected with result code '+str(rc))
client.subscribe('devices/1')
# 消息接收回调
def on_message(client, userdata, msg):
print(msg.topic+" "+str(msg.payload))
client.publish('gateway/device/1',payload=f'echo {msg.payload}',qos=0)
client = mqtt.Client()
# 指定回调函数
client.on_connect = on_connect
client.on_message = on_message
# 建立连接
client.connect('127.0.0.1', 1883)
# 发布消息
client.publish('gateway/device/1',payload='Hello, I am device',qos=0)
client.loop_forever()设备2模拟代码 dev2.py
import paho.mqtt.client as mqtt
# 连接成功回调
def on_connect(client, userdata, flags, rc):
print('Connected with result code '+str(rc))
client.subscribe('devices/2')
# 消息接收回调
def on_message(client, userdata, msg):
print(msg.topic+" "+str(msg.payload))
client.publish('gateway/device/2',payload=f'echo {msg.payload}',qos=0)
client = mqtt.Client()
# 指定回调函数
client.on_connect = on_connect
client.on_message = on_message
# 建立连接
client.connect('127.0.0.1', 1883)
# 发布消息
client.publish('gateway/device/2',payload='Hello, I am device',qos=0)
client.loop_forever()


2026-01-29
新法规欧标AC桩一站式技术实现方案
面对欧盟Delegated Regulation (EU) 2025/656条例设定的明确技术路线与2027年强制生效节点,开发符合 EN ISO 15118-20:2022 标准的下一代智能交流充电桩,已成为产品进入欧洲市场的唯一路径。这意味着,传统PWM通信方式即将淘汰,全面转向基于 GreenPHY电力线载波(PLC)的高层通信,并强制集成即插即充(PnC)与车辆到电网(V2G)能力。01硬
2026-01-22
看过来,米尔RK3576 NPU方案你用对了吗?
本文基于米尔MYD-LR3576开发板,详细记录了如何利用500万像素USB摄像头实现640×640分辨率的YOLO5s目标检测,并将结果实时输出至1080P屏幕的全流程。通过系统级的软硬件协同优化,最终将端到端延迟控制在40ms以内,实现了 20FPS的稳定实时检测性能。文章重点剖析了摄像头特性分析、显示通路选择、RGA硬件加速、RKNN NPU集成等关键技术环节,为嵌入式AI视觉系统的开发与调
2026-01-22
全场景工控与网关解决方案:从入门到旗舰的一站式选型
在工业自动化与物联网向深度智能迈进的浪潮中,工业设备对成本控制、运行可靠性及智能算力的要求正持续攀升。无论是追求极致性价比的基础工控终端,还是需要强劲算力支撑的AIoT边缘节点,开发者都在为不同场景寻觅适配的“工业之芯”。对此,我们基于MYC-YR3506、MYC-LT536、MYC-LR3576三款核心板,打造了覆盖低、中、高端全场景的工业控制与网关解决方案,以一站式选型体系,助力工业产品实现“
2026-01-15
当国产芯遇上机器人:RK3576的ROS2奇幻之旅
当RK3576的强劲“大脑”(四核A72+四核A53)与强大的GPU、VPU、NPU加速模块相遇,一场高性价比的机器人开发革命正在悄然发生。我们成功将完整的Ubuntu 22.04与ROS2 Humble生态系统,完美移植到了这颗国产芯片上。一个稳定、全功能的机器人软件开发平台已经就绪,现在就来一起探索它的强大魅力!一、系统启动与基础性能展示1.硬件平台简介开发板:MYD-LR3576存储:eMM
2026-01-15
内置全栈安全,一站式满足CRA法案与IEC 62443标准-米尔MYC-LF25X核心板
面对日益严峻的网络安全挑战,欧盟《网络弹性法案》(CRA)的出台与工业安全标准IEC 62443的广泛应用,为设备制造商筑起了新的合规门槛。安全不再是可选功能,而是产品设计的强制基石。米尔电子推出的MYC-LF25X嵌入式处理器模组,基于已通过SESIP 3级认证的意法半导体STM32MP257F处理器,提供从硬件信任根到应用层的全栈、可验证安全架构,是您高效开发符合国际法规与标准的安全关键型应用
2025-12-26
补贴太香了!158元买米尔NXP i.MX 91开发板,限购300套
太香了!限时补贴狂欢,回馈您的支持!米尔基于NXP i.MX 91开发板仅158元,限量300套,先到先得。该开发板基于新一代NXP i.MX 91系列处理器设计,搭载Arm Cortex-A55核心,集成双千兆以太网和双 USB 端口等丰富外设,支持Linux、Android等主流操作系统,赋能新一代入门级Linux应用,适用于工业控制、智能终端、物联网等领域的原型开发与教学实践。产品型号:MY
2025-12-19
Buildroot MQTT-Modbus 网关开发,实现设备远程监控方案-米尔RK3506
在工业物联网与智能家居场景中,远程设备监控的核心痛点是工业总线协议与物联网协议的兼容性问题。基于RK3506 Buildroot系统开发的MQTT-Modbus网关产品,通过协议桥接技术完美解决这一难题,为低成本、高可靠的远程监控提供了高效解决方案。一、核心开发平台与技术选型硬件平台选用RK3506处理器作为网关核心硬件,该芯片具备低功耗、高性价比特性,支持多接口扩展,完全适配工业级嵌入式场景需求
2025-12-19
SDK重磅升级,RK3506核心板解锁三核A7实时控制新架构
在工业控制与边缘智能领域,开发者的核心需求始终明确:在可控的成本内,实现可靠的实时响应、稳定的通信与高效的开发部署。米尔电子基于RK3506处理器打造的MYC-YR3506核心板平台,近期完成了一次以“实时性”和“可用性”为核心的SDK战略升级,致力于将多核架构的潜力转化为工程师可快速落地的产品力。本次升级围绕两大主线展开:系统生态的多样化与实时能力的深度释放。我们不仅提供了从轻量到丰富的操作系统
2025-12-11
赋能欧标充电桩市场:OCPP协议实战开发指南
随着全球电动汽车产业的迅猛发展,充电基础设施的智能化与标准化已成为行业迫切需求。OCPP(Open Charge Point Protocol即开放充电点协议)作为连接充电桩与中央管理系统的"通用语言",正成为解决设备互联互通难题的关键技术。一、OCPP:为何是出海欧标的必选项?OCPP是一个开放、标准的通信协议,它确保了不同制造商生产的充电桩能够与任何兼容的后台管理系统进行无
2025-12-11
打造本地化智能的“最强大脑”, 米尔RK3576 AI边缘计算盒
在人工智能与边缘计算深度融合的浪潮中,本地化智能需求正重塑产业格局。米尔电子推出的RK3576边缘计算盒,具备高算力、低功耗与强扩展性,凭借其卓越的硬件架构与多场景适配能力,正成为推动工业视觉、工程机械及智慧城市等领域智能化产业升级的有力工具。米尔MYD-LR3576-B边缘计算盒基于瑞芯微中高端RK3576芯片,采用异构计算架构,集成4核Cortex-A72与4核Cortex-A53处理器,搭配