博客
关于我
501-STM32+Air724UG基本控制篇(自建物联网平台)-移植使用-移植单片机MQTT底层包到自己的工程项目
阅读量:147 次
发布时间:2019-02-28

本文共 1603 字,大约阅读时间需要 5 分钟。

说明

这节详细说明一下如何把工程里面的MQTT包移植到用户自己的工程.

注意:首先确定自己已经实现了使用TCP连接服务器!

该底层包适用于所有的单片机,和所有的网络模块.

该教程以STM32工程为例子说明移植过程.

文件夹说明

1.移植使用的是下面两个文件夹里面的文件

我准备了一个空模板程序,然后在这个模板上演示移植过程.

 

 

 

2.MQTT文件夹

 

 

 

mqtt_msg 文件作为最底层的最直接的MQTT协议处理文件.

mqtt.c 文件 是我在mqtt_msg的基础上又封装了一层

这一层增加了数据缓存管理,缓存管理采用环形队列实现,所有的数据都储存在缓存里面

另一方面还有处理消息等级1,2的消息,心跳包自动发送等.

有了这一层的封装,用户只需简单的配置即可实现稳定可靠的MQTT通信.

 

3.mem文件夹

 

 

 

mem文件夹里面是我写的缓存管理程序

 

开始移植 

1.把文件添加到工程,设置下.h路径

 

2.编译一下工程,打开这个错误

 

 

 

3.替换自己的TCP发送函数

 

 

 

4.把 mqtt_time_data(&mymqtt); 放到1ms定时器中断中.

 

 

 

 

 

 

 

5.初始化和注册MQTT几个函数,订阅,发布等函数

 

 

6.连接TCP服务器,发送连接MQTT协议

 

 

 

把上面的协议发给MQTT服务器以后,MQTT服务器会返回数据

需要把返回的数据交给 int  mqtt_connect_ack(unsigned char *buff) 函数处理

如果该函数返回 0 说明连接上了MQTT服务器,然后调用 mymqtt.connectCb();执行连接回调函数

 

 

 

 

 

 

7.加上需要不停轮训的函数和处理MQTT消息的函数

 

 

 

 

8.按照上面的步骤已经移植完成(述说下执行流程)

1.首先控制模块以TCP方式连接服务器,连接上以后发送MQTT连接协议

 

 

 

2.判断服务器返回的数据,如果连接上MQTT服务器,调用连接成功回调函数

并在连接成功回调函数中订阅主题.

 

 

 

 

 

 

 

3.订阅主题的协议都打包进了缓存,从缓存提取并发送出去.

注:后面发布消息,发送心跳包数据也是全部打包进了缓存!

 

 

 

 

 

 

 

 

4.MQTT服务器返回数据以后,解析处理MQTT返回的数据

 

 

 

 

 

 

 

 

 

5.如果接收到普通的通信消息,将会调用接收数据回调函数

 

 

 

6.发布消息

只要判断成功连接了MQTT,发送消息的函数可以写到任意地方 .

 

 

 

 

 

 

 

注意事项

 

1.在mqtt.h里面 有一个 mqtt_send_buff_len 500

该变量控制着发送协议的最大长度,用户需要根据自己的情况修改该值.

为防止提取缓存时导致内存溢出,我编写底层的时候设置了默认超过该值的打包协议将被丢弃.

 

 

 

 

 

2.发布消息成功函数只有在消息等级1和消息等级2的时候才会进入

消息等级1和消息等级2服务器只要应答便会进入此函数.说明服务器确实接收到了数据.

 

 

 

 

3.假设自己的网络模块并非透传模式

假设使用的串口2和模块进行的通信

1.发送数据,假设发送66个数据

1.1 首先发送 AT+CIPSEND=66\r\n    66:为要发送的数据个数

1.2 等待模块返回 >

1.3 发送要发送的数据给模块

1.4 模块返回 Recv 66 bytes  

1.5 模块发送完成返回 SEND OK

2.接收数据

2.1 接收数据格式: +IPD,XXXX:真实数据    XXXX 为接收的数据个数

 

修改 mqtt_send_function里面的发送过程

 

 

 

如果接收到 > 清零接收超时

如果 接收到 SEND OK 清零发送超时

 

 

 

接收的数据直接提取有效数据,然后交于 mqtt_read_function函数处理

 

 

 

4.如果内存允许,建议采用下面的方式处理接收数据

 

 

 

5.如果客户发现自己当前的版本和细节介绍的有出入

请用户直接把此节的文件移植替换当前使用的文件

随着时间的推移,我可能会发现并修改完善许多细节

我会尽量做到版本兼容!

如若有不兼容的地方,我将在文件说明中做详细说明.

转载地址:http://fcdc.baihongyu.com/

你可能感兴趣的文章
NIFI1.21.0最新版本安装_配置使用HTTP登录_默认是用HTTPS登录的_Https登录需要输入用户名密码_HTTP不需要---大数据之Nifi工作笔记0051
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
NIFI同步MySql数据源数据_到原始库hbase_同时对数据进行实时分析处理_同步到清洗库_实际操作06---大数据之Nifi工作笔记0046
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>