RyanMqtt 2.0
RT-Thread 社區(qū)精品軟件包 RyanMqtt 發(fā)布 2.0 新版本!
更輕、更快、更安全、更可靠,為你的物聯(lián)網(wǎng)連接注入新動力。
軟件包地址:https://packages.rt-thread.org/detail.html?package=RyanMqtt
原文鏈接,歡迎討論:https://club.rt-thread.org/ask/article/3d5f29ae6ac922e0.html
核心亮點(diǎn)
維度 | 變更類型 | 核心價值 |
協(xié)議棧 | Paho MQTT Embedded → coreMQTT | 社區(qū)維護(hù)活躍、測試覆蓋完善,為未來 MQTT 5.0 支持奠定基礎(chǔ) |
運(yùn)行時安全分析驗(yàn)證 | 使用 Sanitizer 進(jìn)行運(yùn)行時安全分析驗(yàn)證 | 調(diào)試階段捕獲內(nèi)存越界、Use-after-free、數(shù)據(jù)競爭、未定義行為、內(nèi)存泄漏等問題,提升代碼健壯性與安全性 |
高質(zhì)量代碼保障 | 引入 clang-tidy 和 Cppcheck 進(jìn)行靜態(tài)分析 | 高質(zhì)量代碼保障,接近語法級”零缺陷“,顯著提升可維護(hù)性 |
AI 輔助開發(fā)與審查 | 使用 coderabbitai 和 Copilot 輔助編碼與代碼審查 | AI 輔助開發(fā)與審查,持續(xù)提升代碼質(zhì)量,構(gòu)筑安全防線 |
內(nèi)存管理優(yōu)化 | 固定緩沖區(qū) →動態(tài)按需分配 | 采用按需動態(tài)分配,降低運(yùn)行內(nèi)存占用 |
線程安全強(qiáng)化 | 更完善的線程安全 | 支撐復(fù)雜線程應(yīng)用場景,杜絕競態(tài)風(fēng)險 |
測試體系升級 | 新增專項(xiàng)測試 | 覆蓋廣泛場景,全鏈路內(nèi)存泄漏檢測,強(qiáng)化穩(wěn)定性與可靠性 |
公共 API 變化
新增接口
// 批量訂閱/取消訂閱externRyanMqttError_eRyanMqttSubscribeMany(RyanMqttClient_t *client,int32_tcount, RyanMqttSubscribeData_t subscribeManyData[]);externRyanMqttError_eRyanMqttUnSubscribeMany(RyanMqttClient_t *client,int32_tcount, RyanMqttUnSubscribeData_t unSubscribeManyData[]);// 帶用戶數(shù)據(jù)的發(fā)布externRyanMqttError_eRyanMqttPublishAndUserData(RyanMqttClient_t *client,char*topic,uint16_ttopicLen, char*payload,uint32_tpayloadLen, RyanMqttQos_e qos, RyanMqttBool_e retain,void*userData);// 線程安全的訂閱查詢,僅可通過 RyanMqttSafeFreeSubscribeResources 進(jìn)行安全釋放。externRyanMqttError_eRyanMqttGetSubscribeSafe(RyanMqttClient_t *client, RyanMqttMsgHandler_t **msgHandles, int32_t*subscribeNum);externRyanMqttError_eRyanMqttSafeFreeSubscribeResources(RyanMqttMsgHandler_t *msgHandles,int32_tsubscribeNum);// 訂閱數(shù)量查詢externRyanMqttError_eRyanMqttGetSubscribeTotalCount(RyanMqttClient_t *client,int32_t*subscribeTotalCount);// 獲取 MQTT Config 信息,僅可通過 RyanMqttFreeConfigFromGet 進(jìn)行安全釋放。externRyanMqttError_eRyanMqttGetConfig(RyanMqttClient_t *client, RyanMqttClientConfig_t **pclientConfig);externRyanMqttError_eRyanMqttFreeConfigFromGet(RyanMqttClientConfig_t *clientConfig);
新增功能價值
接口 | 用途 | 優(yōu)勢 |
SubscribeMany | 批量訂閱/取消多個主題 | 減少網(wǎng)絡(luò)往返,提升吞吐效率 |
PublishAndUserData | 發(fā)布消息附帶上下文 | 回調(diào)中可直接讀取用戶數(shù)據(jù),簡化狀態(tài)管理 |
GetSubscribeSafe | 安全查詢訂閱狀態(tài) | 內(nèi)部同步,多線程安全 |
GetSubscribeTotalCount | 獲取訂閱總數(shù)量 | 便于監(jiān)控與資源調(diào)度 |
平臺抽象層優(yōu)化
1. 統(tǒng)一時間接口
uint32_tplatformUptimeMs(void);
跨平臺毫秒級運(yùn)行時間
內(nèi)部處理 32 位回繞,長時間運(yùn)行穩(wěn)定
2. 網(wǎng)絡(luò)收發(fā)模型簡化
收發(fā)接口改為單次調(diào)用語義,減少冗余循環(huán)與分支
返回實(shí)際傳輸字節(jié)數(shù),更貼近底層行為
異常恢復(fù)路徑更明確
測試體系全面升級
新增8 大類專項(xiàng)測試用例,覆蓋從基礎(chǔ)功能到極限壓力場景的全流程驗(yàn)證:
測試類別 | 測試目標(biāo) |
1. 客戶端銷毀壓力測試 | 驗(yàn)證資源釋放的冪等性與完整性 |
2. 心跳與超時處理 | Keep-Alive、PINGREQ/RESP 機(jī)制驗(yàn)證 |
3. 消息鏈路完整性(QoS 0/1/2 | QoS 0/1/2 消息端到端可靠性驗(yàn)證 |
4. 自動/手動重連機(jī)制 | 狀態(tài)機(jī)正確性與連接恢復(fù)能力 |
5. 批量/重復(fù)訂閱一致性 | 訂閱表一致性、內(nèi)存安全、去重邏輯 |
6. 多客戶端高并發(fā) | 20+ 客戶端并發(fā)運(yùn)行穩(wěn)定性 |
7. 單客戶端多線程共享(20 線程 × 各 1000 條 QoS1/2 消息) | 鎖機(jī)制、數(shù)據(jù)一致性、競態(tài)防護(hù) |
8. 公共API參數(shù)校驗(yàn) | 提升接口健壯性與可用性 |
測試覆蓋范圍
基礎(chǔ)連接:100 次循環(huán)連接/斷開,混合 QoS 消息與訂閱
消息流控:連續(xù)發(fā)送 QoS0/1/2 等級 1000 條消息,混合 QoS 壓力測試
訂閱管理:批量、大量、重復(fù)、混合 QoS 訂閱與取消
并發(fā)壓測:
單客戶端 20 線程 × 各 1000 條 QoS1/2 消息
多客戶端 20 并發(fā)實(shí)例進(jìn)行雙向發(fā)布/訂閱
可靠性:長連接、弱網(wǎng)、Keep-Alive、重連機(jī)制驗(yàn)證
資源安全:全鏈路內(nèi)存泄漏、句柄泄漏檢測
代碼質(zhì)量與規(guī)范
工具鏈全面集成
工具 | 用途 |
Sanitizer | 運(yùn)行時捕獲內(nèi)存與線程安全問題 |
clang-tidy | 靜態(tài)分析潛在缺陷(空指針、資源泄漏等) |
Cppcheck | 深度掃描內(nèi)存與資源問題 |
ClangFormat | 統(tǒng)一代碼風(fēng)格 |
編譯器警告 | -Wall -Wextra(默認(rèn))、-Weffc++/-Weverything(Clang 可選,CI 強(qiáng)化時開啟) |
檢查重點(diǎn)覆蓋
內(nèi)存安全:杜絕泄漏、越界、懸空指針
性能優(yōu)化:減少冗余拷貝與低效算法
可讀性:命名規(guī)范、注釋完整、邏輯清晰
成果:實(shí)現(xiàn)接近語法級”零缺陷“,長期維護(hù)成本大幅降低
安全性與可靠性全面提升
公共 API 全面審查
核心數(shù)據(jù)結(jié)構(gòu)訪問均受同步機(jī)制保護(hù)
動態(tài)內(nèi)存策略更健壯,異常路徑也能安全釋放
輸入驗(yàn)證與邊界檢查更嚴(yán)格,防御性編程增強(qiáng)
網(wǎng)絡(luò)異常處理更完善,弱網(wǎng)環(huán)境下連接恢復(fù)更快
錯誤恢復(fù)路徑更穩(wěn)健,超時策略更精準(zhǔn)
總結(jié)
本次 RyanMqtt 2.0 是一次具有里程碑意義的升級:
技術(shù)棧現(xiàn)代化:遷移至 coreMQTT,擁抱更活躍的生態(tài)與未來擴(kuò)展能力
架構(gòu)更清晰:模塊高度解耦,抽象設(shè)計更合理
質(zhì)量更可信:專項(xiàng)測試 + 靜態(tài)分析 + AI 審查構(gòu)筑強(qiáng)大防線
性能再優(yōu)化:更低資源占用、更高吞吐效率
維護(hù)更輕松:統(tǒng)一代碼規(guī)范、平臺抽象降低長期開發(fā)成本
從 1.x 遷移至 2.x
RyanMqtt 2.0 在設(shè)計上盡量減少破壞性變更。升級過程極為簡單:
從V1.x升級到V2.x時,需在RyanMqttClientConfig_t結(jié)構(gòu)體中移除以下四個已廢棄字段:
char*recvBuffer; // MQTT 接收緩沖區(qū)(已廢棄)char*sendBuffer; // MQTT 發(fā)送緩沖區(qū)(已廢棄)uint32_trecvBufferSize;// 接收緩沖區(qū)大小(已廢棄)uint32_tsendBufferSize;// 發(fā)送緩沖區(qū)大小(已廢棄)
受影響的主要接口(其余接口原則上兼容,如有差異以頭文件為準(zhǔn)):
RyanMqttError_eRyanMqttSetConfig(RyanMqttClient_t *client, RyanMqttClientConfig_t *clientConfig);// packetType 不再使用enum msgTypes, 新類型請參考 RyanMqttPublic.h 文件內(nèi)MQTT packet types宏定義RyanMqttError_eRyanMqttDiscardAckHandler(RyanMqttClient_t *client,uint8_tpacketType,uint16_tpacketId);
其余 API 與配置保持兼容,無需額外修改即可完成遷移。若編譯期出現(xiàn)不兼容,請以 mqttclient/include/*.h 中的最新簽名為準(zhǔn)。
強(qiáng)烈建議所有用戶都升級到2.0!選擇latest就是2.0版本,已在公司項(xiàng)目運(yùn)行好幾個月
不準(zhǔn)備升級到2.0的用戶可以選擇1.2.1版本,是V1的最后一個版本
RyanMqtt github倉庫:
https://github.com/Ryan-CW-Code/RyanMqtt
RT-Thread社區(qū)軟件包:
https://packages.rt-thread.org/detail.html?package=RyanMqtt
20250916更新
RyanMqtt核心庫細(xì)節(jié)優(yōu)化、test新增3個測試?yán)?/p>
測試類別 | 測試目標(biāo) |
隨機(jī)網(wǎng)絡(luò)故障弱網(wǎng)丟包測試 | 在弱網(wǎng)及高丟包環(huán)境下,完成 QOS 全等級消息完整性與內(nèi)存回收驗(yàn)證 |
隨機(jī)網(wǎng)絡(luò)故障內(nèi)存回收檢測 | 驗(yàn)證異常網(wǎng)絡(luò)情況下的內(nèi)存釋放,提升接口健壯性與可用性 |
隨機(jī)內(nèi)存故障,內(nèi)存回收測試 | 驗(yàn)證內(nèi)存異常情況下的資源釋放,提升接口健壯性與可用性 |
20251013更新
修復(fù)客戶端銷毀邏輯:在 init 后未執(zhí)行 start 即銷毀時,資源無法釋放的問題
支持零長度字符串:clientId、userName、password 現(xiàn)在允許長度為 0
內(nèi)存優(yōu)化:降低 Config 內(nèi)存占用
測試增強(qiáng):補(bǔ)充對應(yīng)的單元測試代碼
RT-Thread Github 開源倉庫,歡迎撒個星(Star)支持,更期待你的代碼貢獻(xiàn):https://github.com/RT-Thread/rt-thread
-
物聯(lián)網(wǎng)
+關(guān)注
關(guān)注
2942文章
47414瀏覽量
409151 -
軟件
+關(guān)注
關(guān)注
69文章
5303瀏覽量
91068 -
RT-Thread
+關(guān)注
關(guān)注
32文章
1551瀏覽量
44351
發(fā)布評論請先 登錄
RT-Thread Studio V2.3.0 版本正式發(fā)布!
敢不敢讓你的芯片上榜?RT-Thread最全BSP支持清單重磅更新!| 技術(shù)集結(jié)
元服務(wù)發(fā)布選擇待發(fā)布軟件包
首搭RT-Thread程翧車控平臺| RT-Thread程翧 S32K344 快速原型開發(fā)平臺正式上市!| 產(chǎn)品動態(tài)
RT-Thread studio打不開 RT-thread setting界面怎么解決?
為智能汽車打造“安全+效率+生態(tài)”內(nèi)核,RT-Thread睿賽德重磅發(fā)布車控白皮書
請問RT-Thread Studio更新軟件包為什么不成功?
Windows上使用ENV工具開發(fā)基于先楫MCU的RT-Thread應(yīng)用
在Ubuntu上開發(fā)基于先楫MCU的RT-Thread應(yīng)用指南
【好書推薦】RT-Thread第20本相關(guān)書籍!《嵌入式實(shí)時操作系統(tǒng)RT-Thread原理與應(yīng)用》| 技術(shù)集結(jié)
用SPI玩轉(zhuǎn)WiFi,RT-Thread ESP-Hosted驅(qū)動深度適配指南 | 技術(shù)集結(jié)
RT-Thread BSP全面支持玄鐵全系列RISC-V 處理器 | 技術(shù)集結(jié)
讓開發(fā)板暢游網(wǎng)絡(luò):RT-Thread CherryUSB 驅(qū)動 RNDIS 模塊詳解 | 技術(shù)集結(jié)
2025 RT-Thread全球技術(shù)大會議程正式發(fā)布!

RT-Thread軟件包,RyanMqtt 2.0 發(fā)布,全面重構(gòu):更輕、更快、更安全、更可靠 | 技術(shù)集結(jié)
評論