Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
MQTT
10
KAWAII MQTT 问题求助
发布于 2021-06-13 15:36:40 浏览:1208
订阅该版
各位朋友端午节快乐!!!! 求助一下,在做室内定位产品,使用到 KAWAII MQTT 与服务器通讯。 先介绍一下我的配置: 1. 创建一个 mqtt client 2. 创建两个发布消息,分别为**pm/status** 和 **pm/rawdata**;并启动对应线程,线程栈大小2048;这两个发布分别为**发送本机状态数据** 和 **发送原始数据**。 3. 创建两个订阅消息,分别为**pm/$00000b07/configuration** 和 **pm/configuration**;这两个订阅分别为订阅本机设置消息,订阅广播设置消息,有接收就要有回应,同时开启了两个回应线程,线程栈大小2048,回应的名字都是**pm/events**。 4. Qos 等级为 1。 5. 由于QOS 1 需要有服务器的响应,所以需要把发出去的消息暂存一下等服务器响应了销毁,但是这样带来的问题就是栈空间占用太大,并且我还将发送的二进制 base64 一下,base64 还是在线程内 malloc 的。所以有了以下的思路,判断一下mqtt_ack_handler_number,反正本地有缓存实时性不是要求特别高: 5.1 pm/status 线程 ```C static void thread_mqttpub_status(void *parameter) { PackerMQTTPub_Type_Def* packer_status_param = (PackerMQTTPub_Type_Def*) parameter; while (1) { if(packer_status_param->clientparam.client_param->mqtt_ack_handler_number == 0) { packer_pack_mqttpub(packer_status_param, RT_NULL, 0, 0); rt_thread_delay(10000); } else { rt_thread_delay(RT_TICK_PER_SECOND); } } } ``` 5.2 pm/rawdata 线程; 我是将数据放入缓存,再发送,并且每次发送不大于512字节 ```C static void thread_mqttpub_rawdata(void *parameter) { PackerMQTTPub_Type_Def* packer_rawdata_param = (PackerMQTTPub_Type_Def*) parameter; rt_uint8_t PayloadCnt_Param = 0; while (1) { #ifdef EXIST_DWT2 if(((type_dwt1 == DEVICE_TYPE_ANCHOR) && (mode_dwt1.param.b_tdoa)) || ((type_dwt2 == DEVICE_TYPE_ANCHOR) && (mode_dwt2.param.b_tdoa))) #else if((type_dwt1 == DEVICE_TYPE_ANCHOR) && (mode_dwt1.param.b_tdoa)) #endif { if((packer_rawdata_param->clientparam.client_param->mqtt_ack_handler_number == 0) && (SendDataforTdoa_Param->lwrt_datastoretdoa_handle.w != SendDataforTdoa_Param->lwrt_datastoretdoa_handle.r)) { if((SendDataforTdoa_Param->lwrt_datastoretdoa_handle.w - SendDataforTdoa_Param->lwrt_datastoretdoa_handle.r) >= PACKET_PAYLOAD_PUBDATA_LEN_MQTT) { PayloadCnt_Param = PACKET_PAYLOAD_PUBDATA_LEN_MQTT / sizeof(DataStoreTdoa_Type_Def); } else { PayloadCnt_Param = ((SendDataforTdoa_Param->lwrt_datastoretdoa_handle.w - SendDataforTdoa_Param->lwrt_datastoretdoa_handle.r) / sizeof(DataStoreTdoa_Type_Def)); } rt_uint8_t* TdoaData_SendbufferParam = (rt_uint8_t*) rt_malloc(sizeof(DataStoreTdoa_Type_Def) * PayloadCnt_Param); if(TdoaData_SendbufferParam == RT_NULL) { LOG_E("TdoaData_SendbufferParam memory malloc failed = %d !", sizeof(DataStoreTdoa_Type_Def) * PayloadCnt_Param); } lwrb_read(&SendDataforTdoa_Param->lwrt_datastoretdoa_handle, TdoaData_SendbufferParam, sizeof(DataStoreTdoa_Type_Def) * PayloadCnt_Param); packer_pack_mqttpub(packer_rawdata_param, TdoaData_SendbufferParam, sizeof(DataStoreTdoa_Type_Def), PayloadCnt_Param); rt_free(TdoaData_SendbufferParam); } else { rt_thread_delay(RT_TICK_PER_SECOND); } } else { rt_thread_delay(RT_TICK_PER_SECOND); } } } ``` 5.3 pm/$00000b07/configuration 响应pm/events ```C static void thread_mqttresponse_unicast(void *parameter) { PackerMQTTSub_Type_Def* packer_unicast_param = (PackerMQTTSub_Type_Def*) parameter; while (1) { if((packer_unicast_param->clientparam.client_param->mqtt_ack_handler_number == 0) && (subunicast_response.senddata_status == DATA_TYPE_EXIST)) { packer_pack_mqttsub(packer_unicast_param, subunicast_response.buffer, subunicast_response.senddata_length, subunicast_response.senddata_packetcount); subunicast_response.senddata_status &= (~DATA_TYPE_EXIST); } else { rt_thread_delay(RT_TICK_PER_SECOND); } } } ``` 5.4 pm/configuration 响应pm/events ```C static void thread_mqttresponse_radio(void *parameter) { PackerMQTTSub_Type_Def* packer_radio_param = (PackerMQTTSub_Type_Def*) parameter; while (1) { if((packer_radio_param->clientparam.client_param->mqtt_ack_handler_number == 0) && (subradio_response.senddata_status == DATA_TYPE_EXIST)) { packer_pack_mqttsub(packer_radio_param, subradio_response.buffer, subradio_response.senddata_length, subradio_response.senddata_packetcount); subradio_response.senddata_status &= (~DATA_TYPE_EXIST); } else { rt_thread_delay(RT_TICK_PER_SECOND); } } } ``` 6. 现在在测试阶段,pm/status 10s 发送一次数据帧;pm/rawdata 不停的发送,没包数据不大于 512个字节;两个订阅不会发生, pm/events 也不会发生。 7. 平时使用很好,但是偶尔会报错,找了几天问题没发现,连接笔记本 开启 终端 不停监控,终于在昨天发现了。问题如下: ![Error.png](https://oss-club.rt-thread.org/uploads/20210613/980925eca452e2f028e48ed2bba3e778.png.webp) 8. 恳请各位路过的大神朋友给予指点,上述问题说的是 空间不足,但是我再发送之前都 if 了 ack num呀。并且 这个问题有时候一天不出,有是有2小时 3小时就出现。
查看更多
zhkag
2021-06-13
这家伙很懒,什么也没写!
内存多次申请释放,导致内存碎片化了吧,建议使用动态内存 ![image.png](https://oss-club.rt-thread.org/uploads/20210613/d2e6dc38066c1081bc36a2b59d3451ad.png)
2
个回答
默认排序
按发布时间排序
flashman2002
2021-06-13
这家伙很懒,什么也没写!
估计要使用内存池技术了,以防止内存使用碎片化。
撰写答案
登录
注册新账号
关注者
0
被浏览
1.2k
关于作者
zhujie
这家伙很懒,什么也没写!
提问
27
回答
13
被采纳
2
关注TA
发私信
相关问题
1
umqtt 软件包使用后,连接上emqx服务器,过一会儿就掉线了
2
使用正点原子的 潘多拉 开发板 的例程19_iot_mqtt
3
mqtt软件包,不支持直接关闭?
4
kawaii_mqtt 申请内存崩溃
5
_signal_entry() 函数中dbg_enter在哪里定义呢?
6
start to connect mqtt server 失败
7
MQTT 在“ read 0:1, break “后断开重连
8
paho_mqtt线程相关疑问
9
RT thread studio kawaii mqtt 无法连接EMQ
10
调试bc26 ,断言错误failed at rt_thread_timeout
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
简单两步配置RTT源码阅读环境 vsc+clangd
2
恩智浦[FRDM-MCXN947]初探 之 ADC与DAC
3
LVGL使用字库IC芯片显示中文
4
基于STM32H750和Rt-Thread的CANFD通信实现的记录(一)
5
freemodbus主机在freertos的适配,参考rtthread例程
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
WIZnet_W5500
UART
ota在线升级
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
SFUD
msh
rt_mq_消息队列_msg_queue
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1443
个答案
289
次被采纳
张世争
805
个答案
174
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
148
次被采纳
本月文章贡献
出出啊
1
篇文章
4
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
1
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部