通过物联网管理多台MQTT设备-基于米尔T527开发板
2024-05-10
2113
来源:米尔电子
本篇测评由电子工程世界的优秀测评者“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()


2025-12-11
打造本地化智能的“最强大脑”, 米尔RK3576 AI边缘计算盒
在人工智能与边缘计算深度融合的浪潮中,本地化智能需求正重塑产业格局。米尔电子推出的RK3576边缘计算盒,具备高算力、低功耗与强扩展性,凭借其卓越的硬件架构与多场景适配能力,正成为推动工业视觉、工程机械及智慧城市等领域智能化产业升级的有力工具。米尔MYD-LR3576-B边缘计算盒基于瑞芯微中高端RK3576芯片,采用异构计算架构,集成4核Cortex-A72与4核Cortex-A53处理器,搭配
2025-12-05
从两轮车仪表到工程机械环视,米尔用国产芯打造“越级”显控体验
在工业4.0 与智能化浪潮的推动下,传统工业设备正在经历一场“交互革命”。从电动两轮车的智能仪表,到工程机械的 360° 环视中控,用户对“更高清的显示、更流畅的触控、更丰富的互联”提出了严苛要求。然而,面对复杂的工业现场,开发者往往面临两难:低端市场(如仪表、充电桩):传统MCU 跑不动复杂界面,上 Linux/安卓方案成本又太高。中高端市场(如工程机械、医疗):多路视频输入(如360环视)需要
2025-12-05
【深度实战】米尔MYD-LR3576 AMP非对称多核开发指南:从配置到实战
一、什么是AMP?为什么重要?AMP(Asymmetric Multi-Processing)非对称多处理架构,允许单个芯片的不同核心运行不同的操作系统或裸机程序。相比传统的SMP(对称多处理),AMP具有独特优势。核心特性:异构运算:不同核心运行最适合的操作系统,如Linux处理复杂应用,RT-Thread保障实时任务;资源隔离:各核心拥有独立内存空间,避免资源冲突;灵活通信:通过共享内存、RP
2025-11-27
为机器人开发赋能,米尔RK3576环视方案解析
一、项目背景与测试平台本次360环视系统原型基于米尔电子MYD-LR3576开发板进行构建与评估。该开发板所搭载的瑞芯微RK3576芯片,集成了4核Cortex-A72、4核Cortex-A53、Mali-G52 GPU及高达6TOPS算力的NPU。本文旨在通过实际测试数据,从功能实现、实时性能与AI拓展潜力三大核心维度,为客户提供一份关于该平台在360环视应用中能力的真实参考。二、系统流程与功能
2025-11-13
助力V2G,SECC GreenPHY实战开发
随着电动汽车与电网双向交互(V2G)技术的快速发展,充电桩与车辆间的高效通信成为实现智能能源管理的关键。SECC作为充电桩的通信控制核心,其与电力线载波通信芯片的适配尤为重要。本文将分享基于米尔核心板,调试联芯通MSE102x GreenPHY芯片的实战经验,为V2G通信开发提供参考。MSE102x芯片介绍联芯通MSE102x系列芯片是一款专注于电动汽车充电通信和智能能源管理的GreenPHY电力
2025-11-13
定制未来,共建生态,米尔出席安路研讨会
在数字化浪潮席卷全球的今天,FPGA技术正成为驱动创新的核心引擎。2025年11月12日,米尔出席安路科技2025 AEC FPGA技术沙龙•北京专场,与技术专家及行业伙伴齐聚一堂,探讨前沿技术趋势,解锁场景化定制方案,共建开放共赢的FPGA新生态!米尔活动现场论坛上,米尔电子产品经理Jeson发表题为“基于DR1M90 FPSOC的工业应用方案”的演讲。演讲介绍了米尔作为嵌入式领域的领军企业,在
2025-11-11
RK3576开发板
RK3576开发板是米尔电子推出的开发板,于2024年10月上市。RK3576开发板是基于瑞芯微RK3576搭载了四核A72与四核A53处理器,主频2.2GHz。RK3576集成了6TOPS的NPU,支持多种深度学习框架,能够处理复杂的AI算法,提高监控效率,降低误报率。RK3576的主芯片采用了八核大小核架构,包括四核Cortex-A72和四核Cortex-A53,
2025-11-11
RK3576核心板
RK3576核心板是深圳米尔电子旗下产品,是基于瑞芯微RK3576搭载了四核A72与四核A53处理器,主频高达2.2GHz。RK3576集成了6TOPS的NPU,支持多种深度学习框架,能够处理复杂的AI算法,提高监控效率,降低误报率。RK3576的主芯片采用了八核大小核架构,包括四核Cortex-A72和四核Cortex-A53,主频分别高达2.2GHz和1.8GHz,CPU算力达58K DMIP
2025-11-06
米尔SECC方案助力国标充电桩出海
随着电动汽车与电网融合加速,国标(GB/T 27930)充电桩出海面临欧标(ISO 15118 / DIN 70121)兼容挑战。米尔电子的 SECC (供电设备通信控制器) 方案,实现协议转换、安全通信及参考开发平台,助力充电桩厂商快速进军海外市场。
2025-11-06
MYD-LD25X Cortex-M33实时核开发实战解析
在嵌入式系统设计中,如何平衡高性能计算与实时控制一直是工程师面临的挑战。STM32MP257的异构架构为这一难题提供了优雅的解决方案,而其中的Cortex-M33实时核更是实现硬实时性能的关键所在。一、异构架构:分工明确,效能卓越STM32MP257采用创新的双核子系统设计:Cortex-A35应用核(双核1.5GHz):运行Linux系统,负责复杂UI、网络通信、文件管理等非实时任务。Corte