|
|
пре 3 година | |
|---|---|---|
| .vscode | пре 3 година | |
| common | пре 3 година | |
| docs | пре 3 година | |
| example | пре 3 година | |
| mqttclient | пре 3 година | |
| pahoMqtt | пре 3 година | |
| rtthread | пре 3 година | |
| .gitignore | пре 3 година | |
| LICENSE | пре 3 година | |
| README.md | пре 3 година | |
| SConscript | пре 3 година |
RyanMqtt 实现了 MQTT3.1.1 协议的客户端。此库针对资源受限的嵌入式设备进行了优化。
初衷:在使用RT-Thread时,没有非常合适的 mqtt 客户端。项目中 mqtt 又是非常核心的功能。随即参考 MQTT3.1.1 标准和项目需求设计的 mqtt 客户端,它拥有以下特点。
RyanMqtt 设计时参考了mqttclient、esp-mqtt、coreMQTT。
RyanMqtt库希望应用程序为以下接口提供实现:
RyanMqtt需要RTOS支持,必须实现如下接口才可以保证mqtt客户端的正常运行
| 函数名称 | 函数简介 |
|---|---|
| platformMemoryMalloc | 申请内存 |
| platformMemoryFree | 释放已申请内存 |
| platformDelay | 毫秒延时 |
| platformThreadInit | 初始化线程 |
| platformThreadStart | 开启线程 |
| platformThreadStop | 挂起线程 |
| platformThreadDestroy | 销毁线程 |
| platformMutexInit | 初始化互斥锁 |
| platformMutexLock | 获取互斥锁 |
| platformMutexUnLock | 释放互斥锁 |
| platformMutexDestroy | 销毁互斥锁 |
| platformCriticalEnter | 进入临界区 / 关中断 |
| platformCriticalExit | 退出临界区 / 开中断 |
RyanMqtt依赖于底层传输接口 API,必须实现该接口 API 才能在网络上发送和接收数据包
MQTT 协议要求基础传输层能够提供有序的、可靠的、双向传输(从客户端到服务端 和从服务端到客户端)的字节流
| 函数名称 | 函数简介 |
|---|---|
| platformNetworkConnect | 根据ip和端口连接服务器 |
| platformNetworkRecvAsync | 非阻塞接收数据 |
| platformNetworkSendAsync | 非阻塞发送数据 |
| platformNetworkClose | 断开mqtt服务器连接 |
RyanMqtt依靠函数生成毫秒时间戳,用于计算持续时间和超时,内部已经做了数值溢出处理
| 函数名称 | 函数简介 |
|---|---|
| platformUptimeMs | 自系统启动以来ms时间戳 |
RT-Thread 平台
其余平台暂无示例
RT-Thread 内置 ulog 组件,方便的使用 ulog api 来管理 RyanMqtt 打印信息
如果没有使能 ulog 或者非 RT-Thread 平台,用户需要手动修改 RyanMqttLog.h 文件调整打印等级。