0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

瑞芯微(EASY EAI)RV1126B mqtt

广州灵眸科技有限公司 2026-04-13 17:22 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

1. MQTT简介

MQTT(Message Queuing Telemetry Transport,消息队列遥测传输协议),是一种基于发布/订阅(publish/subscribe)模式的“轻量级”通讯协议。MQTT最大优点在于,用极少的代码和有限的带宽,为连接远程设备提供实时可靠的消息服务。作为一种低开销、低带宽占用的即时通讯协议,使其在物联网、小型设备、移动应用等方面有较广泛的应用。

1.1 发布和订阅

MQTT使用的发布/订阅消息模式,它提供了一对多的消息分发机制,从而实现与应用程序的解耦。这是一种消息传递模式,消息不是直接从发送器发送到接收器(即点对点),而是由MQTT server(或称为 MQTT Broker)分发的。

l 在MQTT通讯过程中,有三种身份,分别是发布者(publisher)、代理(broker)、和订阅者(subscriber)。

l MQTT传输的消息分为:主题(topic)和负载(payload)两部分。

wKgZPGnctbaAe2ReAAA4wcmrfYU140.jpg

发布者向代理(MQTT Broker)发布topic的消息,代理将该消息推送到所有订阅该topic的订阅者。

* 发布消息的客户端就是发布者,订阅topic消息的客户端就是订阅者

1.2 服务质量QoS(Quality of Service levels)

服务质量是 MQTT 的一个重要特性。当我们使用 TCP/IP 时,连接已经在一定程度上受到保护。但是在无线网络中,中断和干扰很频繁,MQTT 在这里帮助避免信息丢失及其服务质量水平。

1.2.1 QoS 0

至多一次,消息发布完全依赖底层 TCP/IP 网络。会发生消息丢失或重复。这一级别可用于如下情况,环境传感器数据,丢失一次读记录无所谓,因为不久后还会有第二次发送。

wKgZPGnctbaAcbm8AABYqkmApeE819.jpg

1.2.2 QoS 1

至少一次,确保消息到达,但消息重复可能会发生。

wKgZO2nctbaAapApAABhOmI5LUA104.jpg

1.2.3 QoS 2

只有一次,确保消息到达一次。这一级别可用于如下情况,在计费系统中,消息重复或丢失会导致不正确的结果。

wKgZPGnctbeAOR2OAABuY5x7gmc254.jpg

* 带有唯一消息 ID 的消息会存储两次,首先来自发送者,然后是接收者。QoS 级别 2 在网络中具有最高的开销,因为在发送方和接收方之间需要两个流.

1.3 开源项目介绍

根据广泛使用情况和社区活跃度,Eclipse Paho C库是目前中最常用的最流行的C语言MQTT客户端开源库,可应用于Windows/MAC/Linux/FreeRTOS/ESP32等平台。

其官网是:https://www.eclipse.org/

其gitHub仓库是:https://github.com/eclipse-paho/paho.mqtt.c

在Ubuntu系统中,既可以通过直接编译gitHub仓库得到所需的库和头文件,也可以通过下方命令直接安装(此步可不执行)

sudo apt-get update sudo apt-get install libpaho-mqtt-dev

虽然Paho C有着支持的平台全,兼容性好的优点。但也有着【API较底层】,易用性差,需要进一步封装的局限性。

因此本文采用Eclipse旗下的另外一个MQTT项目:mosquitto。此项目对于资源受限的嵌入式设备较为合适,虽然没有Paho C那么全面,但也能满足基本需要,并且更加易用。

其官网是:https://mosquitto.org/

在Ubuntu系统中,可以直接通过下方命令进行安装相关开发库:

sudo apt-get update sudo apt-get install libmosquitto-dev

1.4 常规通信模型

一个常规的使用方式:MQTT Server代理程序部署在云端,板卡作为发布者和订阅者进行数据收发通信,通信模型如下。

wKgZO2nctbaAJ1F-AAH4nNMvibE398.jpg

若想在局域网使用,可以在PC平台(Windows/Linux)上部署一个MQTT Server代理程序,板卡作为发布者和订阅者进行数据收发通信,通信模型如下。

wKgZO2nctbeAeRWuAAIxOY6_-qU262.jpg

比如,可以通过以下命令,在Ubuntu系统中部署一个MQTT Server:

sudo apt-get update sudo apt-get install mosquitto sudo systemctl start mosquitto

若要MQTT Server跟随Ubuntu开机启动,可补充执行下方命令:

sudo systemctl enable mosquitto

1.5 演示说明

本文为了便于对demo解说,因此会把【代理】、【订阅者】、【发布者】都部署在【同一台板卡设备】中。

首先对板卡上电、连网。然后通过串口调试或ssh调试,进入板卡后台。安装MQTT相关资源:

sudo apt-get update sudo apt-get install libmosquitto-dev mosquitto sudo systemctl enable mosquitto && sudo systemctl start mosquitto

2. 快速上手

2.1 开发环境准备

如果您初次阅读此文档,请阅读《入门指南/开发环境准备/Easy-Eai编译环境准备与更新》,并按照其相关的操作,进行编译环境的部署

在PC端Ubuntu系统中执行run脚本,进入EASY-EAI编译环境,具体如下所示。

cd ~/develop_environment ./run.sh 2204

wKgZPGkmcrqAUDHhAAGt1XOkqw8819.jpg

2.2 源码下载以及例程编译

在EASY-EAI编译环境下创建存放源码仓库的管理目录:

cd /opt mkdir EASY-EAI-Toolkit cd EASY-EAI-Toolkit

通过git工具,在管理目录内克隆远程仓库

git clone https://github.com/EASY-EAI/EASY-EAI-Toolkit-1126B.git

wKgZO2lgX0qAFDSLAADZOcsxKH0728.jpg

注:

* 此处可能会因网络原因造成卡顿,请耐心等待。

* 如果实在要在gitHub网页上下载,也要把整个仓库下载下来,不能单独下载本实例对应的目录。

进入到对应的例程目录执行编译操作,具体命令如下所示:

cd EASY-EAI-Toolkit-1126B/Demos/netProtocol-mqtt/ ./build.sh

注:

* 由于依赖库部署在板卡上,因此交叉编译过程中必须保持/mnt挂载。

wKgZPGnctbeAFPGAAAFRII0lxhM745.jpg

注:若编译失败,提示找不到mosquitto.h,请查看本文章节:==1.5演示说明==

2.3 例程运行

通过串口调试或ssh调试,进入板卡后台,定位到例程部署的位置,如下所示:

cd /userdata/Demo/netProtocol-mqtt

wKgZO2nctbeAWR71AAAn6x-dGdU934.jpg

首先运行【订阅者】程序,如下所示:

./test-mqtt_subscription &

wKgZPGnctbeAYLhKAAA8dYVm5w8297.jpg

注:

* 若运行失败,提示“连接失败: Connection refused”,请查看本文章节:==1.5演示说明==

* 由于【订阅者】是后台运行,若要重新运行,记得先把它kill掉。

然后接着运行【发布者】程序。如下所示:

./test-mqtt_publish

2.4 运行效果

wKgZO2nctbeANPWiAABc6_ZgPIo289.jpg

API的详细说明,以及API的调用(本例程源码),详细信息见下方说明。

3. Mosquitto库函数说明

本章节介绍本例程涉及mosquitto库的接口使用方法,更多的接口说明参考官网API文档:https://mosquitto.org/api/files/mosquitto-h.html

3.1 引用方式

EASY EAI api库位于本仓库的easyeai-api目录中。为方便客户在本地工程中直接调用我们的EASY EAI api库,此处列出工程中需要链接的库以及头文件等,方便用户直接添加。

wKgZPGnctbeAMIdGAABU9Jty41I020.jpg

API源代码路径为EASY-EAI-Toolkit-1126B/easyeai-api/netProtocol/mqtt/。用户可通过源代码了解接口实现,甚至可对源码进行修改。

3.2 初始化Mosquitto库

设置证书的函数原型为:

int mosquitto_lib_init(void);

具体介绍如下所示。

wKgZPGnctbiAG5CrAAA0_hL2c6M251.jpg

3.3 创建一个新的Mosquitto客户端实例

创建一个新的Mosquitto客户端实例的函数原型为:

struct mosquitto *mosquitto_new(const char *id, bool clean_session, void *userdata);

具体介绍如下所示。

wKgZPGnctbeAa_KXAABeiuw1l_w454.jpg

3.4 设置连接回调函数

用于处理与Broker的连接状态变化,函数原型如下所示。

void mosquitto_connect_callback_set(struct mosquitto *mosq, void (*on_connect)(struct mosquitto *, void *,int));

具体介绍如下所示。

wKgZO2nctbiAe8XNAABMBSBRiZc715.jpg

3.5 设置断开连接回调函数

用于处理与Broker的断开连接事件,函数原型如下所示。

void mosquitto_disconnect_callback_set(struct mosquitto *mosq, void (*on_disconnect)(struct mosquitto *, void *, int));

具体介绍如下所示。

wKgZO2nctbiAYTygAABOeJHAeIQ341.jpg

3.6 设置消息发布回调函数

用于处理消息成功发送到Broker的事件,函数原型如下所示。

void mosquitto_publish_callback_set(struct mosquitto *mosq, void (*on_publish)(struct mosquitto *, void *, int));

具体介绍如下所示。

wKgZO2nctbeAOhWSAABK17nBhtw294.jpg

3.7 设置订阅回调函数

用于处理成功订阅一个或多个主题的事件,函数原型如下所示。

void mosquitto_subscribe_callback_set(struct mosquitto *mosq, void (*on_subscribe)(struct mosquitto *, void *, int, int, const int *));

具体介绍如下所示。

wKgZO2nctbiASR7EAABmeyiMio0340.jpg

3.8 连接到指定的 Broker

函数原型如下所示。

int mosquitto_connect(struct mosquitto *mosq, const char *host, int port, int keepalive);

具体介绍如下所示。

wKgZPGnctbiAFnvVAAA4F5rowJ4881.jpg

3.9 订阅一个主题

函数原型如下所示。

int mosquitto_subscribe(struct mosquitto *mosq, int *mid, const char *sub, int qos);

具体介绍如下所示。

wKgZO2nctbiANP7iAABSXDoyoLQ383.jpg

3.10 发布一条消息到指定主题

函数原型如下所示。

int mosquitto_publish(struct mosquitto *mosq, int *mid, const char *topic, int payloadlen, const void *payload, int qos, bool retain);

具体介绍如下所示。

wKgZPGnctbiAeS3kAAB8S67egXc773.jpg

3.11 与 Broker 断开连接

函数原型如下所示。

void mosquitto_disconnect(struct mosquitto *mosq);

具体介绍如下所示。

wKgZO2nctbiAVydjAAAow2QI728867.jpg

3.12 销毁 Mosquitto 客户端实例

函数原型如下所示。

void mosquitto_destroy(struct mosquitto *mosq);

具体介绍如下所示。

wKgZPGnctbiAFz9JAAAoxpYqQTw536.jpg

3.13 清理并释放 Mosquitto 库使用的资源

函数原型如下所示。

void mosquitto_lib_cleanup(void);

具体介绍如下所示。

wKgZO2nctbiAdMC_AAAg0czv6Ow749.jpg

4. 使用实例

l 发送示例代码路径为:

EASY-EAI-Toolkit-1126B/Demos/netProtocol-mqtt/test-mqtt_publish.c

l 订阅示例代码路径为:

EASY-EAI-Toolkit-1126B/Demos/netProtocol-mqtt/test-mqtt_subscription.c

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 人工智能
    +关注

    关注

    1819

    文章

    50290

    浏览量

    266833
  • 开发板
    +关注

    关注

    26

    文章

    6405

    浏览量

    120547
  • 瑞芯微
    +关注

    关注

    27

    文章

    841

    浏览量

    54647
  • EASY-EAI灵眸科技

    关注

    4

    文章

    95

    浏览量

    3720
  • RV1126B
    +关注

    关注

    0

    文章

    83

    浏览量

    240
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    (EASY EAI)RV1126B 音频输入

    1.声卡资源介绍EASY-EAI-Nano-TB仅有一块由RV1126B主控输出的声卡。通过串口调试或ssh调试,可以进入开发板终端。执行aplay命令查看声卡相关的详细信息,如下所示
    的头像 发表于 12-18 13:41 2547次阅读
    <b class='flag-5'>瑞</b><b class='flag-5'>芯</b><b class='flag-5'>微</b>(<b class='flag-5'>EASY</b> <b class='flag-5'>EAI</b>)<b class='flag-5'>RV1126B</b> 音频输入

    (EASY EAI)RV1126B PWM使用

    1.PWM简介1.1开发板PWM资源1.2查找PWM节点rv1126b的pwm资源表如下:【PWM1CH0】对应的是pwm1_4ch_0,寄存地址为20700000。【PWM1CH1】对应
    的头像 发表于 01-06 10:49 8156次阅读
    <b class='flag-5'>瑞</b><b class='flag-5'>芯</b><b class='flag-5'>微</b>(<b class='flag-5'>EASY</b> <b class='flag-5'>EAI</b>)<b class='flag-5'>RV1126B</b> PWM使用

    (EASY EAI)RV1126B 音频输出

    1.声卡资源介绍EASY-EAI-Nano-TB仅有一块由RV1126B主控输出的声卡。通过串口调试或ssh调试,可以进入开发板终端。执行aplay命令查看声卡相关的详细信息,如下所示
    的头像 发表于 04-01 17:13 8498次阅读
    <b class='flag-5'>瑞</b><b class='flag-5'>芯</b><b class='flag-5'>微</b>(<b class='flag-5'>EASY</b> <b class='flag-5'>EAI</b>)<b class='flag-5'>RV1126B</b> 音频输出

    EASY EAI Nano-TB(RV1126B)开发板试用】+初识篇

    Nano-TB是灵眸科技研发的一款应用于AIoT领域的开发板,它基于RV1126B处理器,集成了4个Cortex-A53及独立的NEON协处理器,它支持4K@30fps的H.
    发表于 10-25 22:06

    EASY EAI Nano-TB(RV1126B)开发板试用】命令行功能测试-shell脚本进行IO控制-灯闪

    接上文【EASY EAI Nano-TB(RV1126B)开发板试用】开箱测评 https://pan.baidu.com/s/15pnbJXPN5TrfV2KfsKaZyQ?pwd=1234 打开
    发表于 11-01 21:26

    EASY EAI Nano-TB(RV1126B)开发板试用】命令行功能测试-shell脚本进行IO控制-红绿灯项目

    接上文【EASY EAI Nano-TB(RV1126B)开发板试用】通过wifi连接,使用ssh登录EASY EAI Nano-TB(
    发表于 11-02 18:34

    EASY EAI Nano-TB(RV1126B)开发板试用】命令行功能测试-shell脚本进行IO控制-红绿灯按钮项目

    0接上文【EASY EAI Nano-TB(RV1126B)开发板试用】命令行功能测试-shell脚本进行IO控制-红绿灯项目-实现开机起动 EASYEAINano-TB(RV1126B
    发表于 11-03 10:00

    请问各位大佬,如何解决, RV1126B 使用 mpp 自带工具 调试时,内核直接报错崩溃!

    请问各位大佬,如何解决, RV1126B 使用 mpp 自带工具 调试时,内核直接报错崩溃! 调试输出如下:
    发表于 11-19 16:01

    EASY EAI Nano-TB(RV1126B)开发板试用】+1、开箱上电

    ,避免因接触不良导致显示或采集异常。 2 硬件解析:强劲AI核心与丰富接口 2.1 核心处理器性能 EASY EAI Nano-TB开发板的核心基于
    发表于 11-19 21:39

    EASY EAI Nano-TB(RV1126B)开发板试用】介绍、系统安装

    ,并介绍了系统镜像安装部署的相关流程。 介绍 EASY-EAI-Nano-TB是灵眸科技研发的一款应用于AIoT领域的AIOT主板。 核心板基于
    发表于 12-23 18:05

    RV1126系列选型指南:从RV1126RV1126B,一文看懂升级差异

    2025年7月,正式发布新一代AI视觉芯片RV1126B。作为其金牌方案商,EASYEAI灵眸科技同步推出搭载该芯片的AIoT核心板EAI11
    的头像 发表于 09-04 10:50 5073次阅读
    <b class='flag-5'>RV1126</b>系列选型指南:从<b class='flag-5'>RV1126</b>到<b class='flag-5'>RV1126B</b>,一文看懂升级差异

    【免费试用】EASY EAI Nano-TB(RV1126B)开发套件评测

    EASY-EAI-Nano-TB是灵眸科技研发的一款应用于AIoT领域的AIOT主板。核心板基于RV1126B处理器设计,并引入了新
    的头像 发表于 09-23 08:09 1228次阅读
    【免费试用】<b class='flag-5'>EASY</b> <b class='flag-5'>EAI</b> Nano-TB(<b class='flag-5'>RV1126B</b>)开发套件评测

    RV1126B特性概述

    RV1126BRockchip在2025年第二季度全新推出的Arm架构AI视觉芯片,搭载4核Cortex-A53与自研3Tops算力NPU。全面替代上一代的
    的头像 发表于 10-09 11:22 2128次阅读
    <b class='flag-5'>瑞</b><b class='flag-5'>芯</b><b class='flag-5'>微</b><b class='flag-5'>RV1126B</b>特性概述

    替代升级实锤!实测RV1126B,CPU性能吊打RV1126

    AI智能芯片迭代提速,推出了全新的Arm架构AI视觉芯片RV1126B,是否替换RV1126,CPU性能是挤牙膏还是大突破。带着这些核
    的头像 发表于 12-11 17:13 2506次阅读
    替代升级实锤!实测<b class='flag-5'>RV1126B</b>,CPU性能吊打<b class='flag-5'>RV1126</b>

    (EASY EAI)RV1126B 人体关键点识别

    的特点。本人员检测算法在数据集表现如下所示:基于EASY-EAI-Nano-TB(RV1126B)硬件主板的运行效率:17个人体关键点索引定义:2.快速上手2.1开发
    的头像 发表于 01-23 10:13 3479次阅读
    <b class='flag-5'>瑞</b><b class='flag-5'>芯</b><b class='flag-5'>微</b>(<b class='flag-5'>EASY</b> <b class='flag-5'>EAI</b>)<b class='flag-5'>RV1126B</b> 人体关键点识别