【行空板K10】利用Nanomq的桥接转发能力实现接入任意的MQTT服务器

目录

引言

K10程序的编写

运行Nanomq

设置Nanomq的桥接到巴法云

结语


引言

行空板K10作为一块物联网开发板,内置了MQTT的支持,不过它的MQTT有限制,只支持阿里云、OneNet、EasyIoT和SIoT4种MQTT服务器。这对想使用其他MQTT服务器的用户来说不太方便。本文就尝试使用Nanmq轻量化MQTT代理的桥接转发功能实现行空板K10访问任意的MQTT服务器。

K10程序的编写

K10的程序仍然使用Mind+编写。程序的基本功能是读取并显示温度信息,然后连接WiFi热点,成功后在连接MQTT服务器,然后发送温度信息到device004主题。

其中在MQTT参数设置部分选择SIoT,因为它是K10所支持的4种服务器中可以部署在局域网的唯一一种,其他三种服务器的IP或域名都是写死的,不能修改。SIoT是DFRobot提供的免费MQTT服务器,但是前面的评测已经说了(【行空板K10】MQTT服务器SIoT V2-CSDN博客),感觉很一般。Mind+的MQTT组件会自动生成clientid,以确保不同开发板产生的id不同,但是不支持自己设置clientid,这使得像巴法云、华为云IoTDA这样的平台就不能直接接入。我们在本地部署EMQ(杭州映云科技有限公司)Nanomq,把它的服务器地址作为SIoT服务器的地址,具体参数设置如下:

在自动生成窗口,可以看到如下的程序:

/*!
 * MindPlus
 * esp32s3bit
 *
 */
#include <DFRobot_Iot.h>
#include "unihiker_k10.h"

// 动态变量
String         mind_s_my_string_variable;
volatile float mind_n_temp;
// 静态常量
const String topics[5] = {"device004","","","",""};
// 创建对象
UNIHIKER_K10 k10;
AHT20        aht20;
uint8_t      screen_dir=2;
DFRobot_Iot  myIot;


// 主程序开始
void setup() {
	k10.begin();
	k10.initScreen(screen_dir);
	k10.creatCanvas();
	mind_n_temp = aht20.getData(AHT20::eAHT20TempC);
	mind_n_temp = (mind_n_temp - 8);
	k10.setScreenBackground(0x000000);
	mind_s_my_string_variable = (String("温度:") + String((String(mind_n_temp))));
	k10.canvas->canvasText(mind_s_my_string_variable, 3, 0xFFFFFF);
	k10.canvas->updateCanvas();
	myIot.wifiConnect("CU_fjGX", "12345678");
	while (!myIot.wifiStatus()) {}
	k10.rgb->write(0, 0x0000FF);
	k10.canvas->canvasText(myIot.getWiFiSoftIP(), 5, 0xFFFF00);
	k10.canvas->updateCanvas();
	myIot.init("192.168.1.216","admin","2741576345294361","public", topics, 1883);
	myIot.connect();
	while (!myIot.connected()) {}
	k10.rgb->write(1, 0x0000FF);
}
void loop() {
	myIot.publish("device004", mind_n_temp);
	delay(5000);
}

运行Nanomq

NanoMQ 是于 2021 年初发布的边缘计算开源项目,是面向物联网边缘计算场景的下一代轻量级高性能 MQTT 消息服务器。这个服务器下载后直接在本地解压就可以了。然后,使用如下命令启动服务器:

nanomq.exe start --conf=../nanomq.conf

我在另外一台电脑上运行MQTTX,然后订阅Nanomq的device004消息。K10开发板启动成功后,连接MQTT服务器,就可以在MQTTX客户端每隔5秒就可以收到消息推送。

设置Nanomq的桥接到巴法云

不是所有MQTT平台都能使用上面的方法进行连接,对于无法连接的平台可以使用Nanomq进行桥接转发数据。桥接是一种连接多个 MQTT 消息中间件的策略。在桥接模式下,节点之间不进行主题树或路由表的复制操作。桥接模式的核心职能包括:根据预定的规则,将消息转发至指定的桥接节点;对桥接节点上的特定主题进行订阅,并在接收到消息后在本地节点或集群内进行传递和转发。

下面以巴法云为例,说明如何利用桥接功能使K10开发板接入MQTT服务器。

Nanomq提供了一个nanomq_bridge.conf文件,我在此基础上进行修改:

首先加入巴法云的登录信息:

# #====================================================================
# # MQTT Broker Bridge
# #====================================================================

bridges.mqtt.emqx1 {
	# # Bridge address: host:port .
	# #
	# # Value: String
	# # Example: mqtt-tcp://127.0.0.1:1883
	# #          tls+mqtt-tcp://127.0.0.1:8883
	# #          mqtt-quic://54.75.171.11:14567
	
	server = "mqtt-tcp://bemfa.com:9501"
	# # Protocol version of the bridge.
	# #
	# # Value: Enum
	# # - 5: mqttv5
	# # - 4: mqttv311
	# # - 3: mqttv31
	proto_ver = 4
	# # The ClientId of a remote bridge.
	# # Default random string.
	# #
	# # Value: String
	clientid="xxxxxxxxxxxxxxx"
	

巴法云默认是用clientid作为登录服务器的标识,所以这里一定要填写。另外,巴法云不支持MQTT 5,所以MQTT版本一定要选MQTT v3.11。 

forwards部分是转发到远端 MQTT 服务器的主题数组,应包括消息主题(remote_topic)、(local_topic)和 QoS (qos)。remote_topic和local_topic可以不同。

	# # Topics that need to be forward to IoTHUB
	# #
	# # Value: String
	# # Example: topic1/#,topic2/#
	forwards = [
		{
			# # Need to forward to remote broker topics
			# #
			# # Value: String
			remote_topic = "device004"
			# # topic reflection with remote_topic
			# #
			# # Value: String
			local_topic = "device004"
		}
		{
			remote_topic = "fwd/topic2"
			local_topic = "topic2"
		}
	]

 然后执行下面的命令:

nanomq.exe start --conf=../nanomq_bridge.conf

 然后在巴法云的后台就可以看到发布者已经登录并发布数据:

使用MQTTX也可以接收到巴法云转发的数据。至此完美实现了功能。 

结语

本文的方法实现了K10开发板接入到任意的MQTT服务器。不过这个方法仍然比较麻烦,因为需要安装一个本地的Nanomq。后面将研究如何写个第三方库,使得K10能够直接接入MQTT服务器。 

<think>好的,我需要帮助用户找到关于在K10系列行空上使用PyCharm的教程或配置方法。首先,我得先理解用户的问题。行空可能是一种特定的开发或硬件设备,而K10系列可能是其型号。用户想在PyCharm中配置或使用这个子进行开发。 首先,我需要回忆PyCharm的基本使用和配置方法。根据用户提供的引用资料,PyCharm有专业版和社区版,社区版免费,适合日常开发[^2]。配置PyCharm时,可以调整内存设置以提升性能[^3]。此外,用户可能需要在PyCharm中设置Python解释器或项目结构[^4]。 接下来,用户的问题涉及特定的硬件——K10行空。这可能意味着需要在PyCharm中配置远程开发环境、设置SSH连接,或者安装特定的插件来支持该硬件。例如,如果行空是基于Linux系统的,可能需要通过远程解释器来连接。 由于用户提供的引用中没有直接提到K10行空,我需要推测可能的配置步骤。例如,可能需要安装针对该硬件的SDK或库,配置部署工具,或者设置调试环境。此外,可能需要参考行空的官方文档,查看是否有PyCharm的集成指南。 另外,考虑到行空可能支持Python,用户可能需要在PyCharm中配置Python解释器路径,指向行空上的Python环境。或者使用远程开发功能,将代码部署到行空上运行。这可能需要安装像“SSH Remote Run”这样的插件,或者使用PyCharm Professional的远程开发功能。 可能的问题包括如何配置远程解释器、如何部署代码到行空、如何调试运行在行空上的代码等。需要逐步引导用户完成这些步骤,并提示他们参考行空的官方文档或社区资源。 最后,生成的相关问题应围绕PyCharm在嵌入式或特定硬件上的使用,例如远程开发配置、插件安装、调试方法等。</think>### PyCharm在K10系列行空上的配置方法 目前公开资料中未明确提及**K10系列行空**与PyCharm的直接集成教程,但可通过以下通用方法实现开发环境配置: --- #### **1. 硬件通信基础配置** - **连接方式**:行空通常支持USB/网络连接,需在PyCharm中配置SSH远程解释器。路径:`File > Settings > Project Interpreter > Add > SSH Interpreter`,输入行空的IP地址和认证信息[^3]。 - **文件传输**:使用`Tools > Deployment > Configuration`设置SFTP,将本地代码自动同步到行空[^4]。 --- #### **2. 依赖管理与调试** - **安装硬件专用库**:通过SSH终端安装行空SDK,例如: ```bash pip install xingkong-board-k10-sdk # 假设的SDK包名,需以官方文档为准 ``` - **远程调试**:在PyCharm中创建`Remote Debug`配置,指定端口和映射路径[^3]。 --- #### **3. 性能优化建议** - 调整PyCharm内存:修改`pycharm.vmoptions`文件,增加`-Xmx2048m`避免卡顿。 - 关闭冗余插件:在`Plugins`中禁用与嵌入式开发无关的插件。 --- #### **官方资源补充** 建议优先查阅行空厂商提供的开发文档,通常包含: - 系统镜像烧录指南 - GPIO/I2C等硬件接口的Python库说明 - 实时数据可视化配置方法 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

神一样的老师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值