来了!合宙Air780EP模组LuatOS脚本开发MQTT应用示例
Air780EP是合宙的低功耗4G模组之一,支持全系列的AT指令以及LuatOS脚本二次开发。
本文同样适用于以下型号:
Air780EPA/Air780EPT/Air780EPS
Air780E/Air780EX/Air201…
一、相关准备工作
1.1 硬件准备
-
合宙EVB_Air780EP开发板一套,包括天线、SIM卡;
-
USB线
-
PC电脑
1.2 软件准备
-
登录合宙官方IoT后台:
https://iot.openluat.com/
-
LuatOS固件下载:
https://gitee.com/openLuat/LuatOS/releases -
DEMO源码下载:
https://gitee.com/openLuat/LuatOS/tree/master/demo/mqtt
注:进入LuatOS固件页面按下Ctrl+F,搜索Air780EP即可找到对应的固件。
推荐选用:相关型号固件名称后面数字版本号最高的最新relase版本进行调试。
二、名词解析及API说明
2.1 名词解析
-
user_name用户名
password密码
client_id用户标识MQTT可以通过前两个参数保证连接的安全,通过client_id确保设备唯一性。
-
QOS消息质量
分为0/1/2三个等级,分别表示只发一次,至少收到一次和只收到一次。通过QOS可以根据数据的重要性灵活,选择发送方式以节省带宽和保证数据可靠。
关于publish时QOS值的说明:
QOS为0时,压入底层TCP发送堆栈,视为成功;QOS为1时,收到服务器回应PUBACK,视为成功;
QOS为2时,收到服务器响应PUBREC,立即上行PUBCOMP压入TCP发送队列,视为成功。
-
mqtt_host主机服务器地址
mqtt_port端口MQTT需要连接的服务器参数。
mqtt_host可以说是ip或者域名。 -
topic主题
根据主题区别消息类型和来源,主要用来分类数据。同时mqtt是发布订阅模型,topic是发布和订阅者通信的重要通道。
-
payload消息内容
发布和订阅的具体数据。
-
retain保留消息
保留消息是一条将保留标志(retained flag)置为true的普通MQTT消息。broker会针对主题依照QoS级别保留最后一条保留消息,当订阅者订阅主题时会立即收到保留消息。broker仅为每个主题保留一条保留消息。
2.2 API说明
API接口 | 描述 |
---|---|
mqtt.create() |
创建一个mqtt client实例 |
mqttc:connect() |
连接mqtt服务器 |
mqttc:subscribe() |
订阅主题 |
mqttc:unsubscribe() |
取消订阅主题 |
mqttc:publish() |
发布消息 |
mqttc:disconnect() |
断开与服务器的连接 |
三、MQTT实现流程
3.1 创建一个TASK协程
接口:
sys.taskInit(func, arg1, arg2, argN)
参数:
传入值类型 | 解释 |
---|---|
function |
待执行的函数,可以是匿名函数, |
any |
需要传递的参数1,可选 |
any |
需要传递的参数2,可选 |
any |
需要传递的参数N,可选 |
返回值类型 | 解释 |
---|---|
task |
协程对象 |
3.3 创建一个mqtt实例
接口:
mqtt.create(adapter,host,port,ssl,isipv6)
参数:
传入值类型 | 解释 |
---|---|
int |
适配器序号, 只能是socket.ETH0, 如果不填,会选择平台自带的方式, |
string |
服务器地址,可以是域名, |
int |
端口号 |
bool/table |
是否为ssl加密连接,默认不加密。 |
bool/table |
bool 是否为ipv6,默认不是。 |
返回值:
返回值类型 | 解释 |
---|---|
userdata |
若成功会返回mqtt客户端实例, |
3.4 连接服务器
接口:
mqttc:connect()
参数:
无
返回值:
返回值类型 | 解释 |
---|---|
boolean |
发起成功返回true, 否则返回false。 |
注意:本函数仅代表发起成功, 后续仍需根据ready函数判断mqtt是否连接正常。
3.5 订阅主题
接口:
mqttc:subscribe(topic, qos)
参数:
传入值类型 | 解释 |
---|---|
string/table |
主题 |
int |
topic为string时生效 0/1/2,默认0 |
返回值:
返回值类型 | 解释 |
---|---|
int |
消息id,当qos为1/2时有效; |
3.6 发布消息
接口:
mqttc:publish(topic, data, qos, retain)
参数:
传入值类型 | 解释 |
---|---|
string |
主题,必填 |
string |
消息,必填,但长度可以是0 |
int |
消息级别 0/1,默认0 |
int |
是否存档 0/1,默认0 |
返回值:
返回值类型 | 解释 |
---|---|
int |
消息id,当qos为1或2时会有效值; |
3.7 接收消息
3.8 断开服务器的连接
接口:
mqttc:disconnect()
参数:
无
返回值:
返回值类型 | 解释 |
---|---|
boolean |
发起成功返回true, 否则返回false。 |
四、MQTT示例说明
本文以demo_lua\LuatOS\demo\mqtt这个demo为例作为演示,以MQTTX工具来测试MQTT运行状况。

订阅主题格式要求默认为 /luatos/pub/ 加模块的IMEI号。
例如:/luatos/pub/868488076506128

格式要求默认为 /luatos/sub/ 加模块的IMEI号。
例如:/luatos/sub/868488076506128



五、MQTT单链接示例
5.1 修改指定参数
local mqtt_host = "lbsmqtt.airm2m.com"
local mqtt_port = 1884
local mqtt_isssl = false
local client_id = "abc"
local user_name = "user"
local password = "password"
local pub_topic = "/luatos/pub/" .. (mcu.unique_id():toHex())
-- 该变量在下方代码有重新赋值,根据实际应用场景,可自行修改脚本逻辑
local sub_topic = "/luatos/sub/" .. (mcu.unique_id():toHex())
-- 该变量在下方代码有重新赋值,根据实际应用场景,可自行修改脚本逻辑
要先等待网络就绪之后,才可进行MQTT后续操作。
https://gitee.com/openLuat/LuatOS/tree/master/demo/mqtt


要使用串口1,且波特率为9600。

六、MQTT多链接示例
多链接的核心,就是要创建两个mqtt客户端的对象,通过不同的变量控制,代码部分如下。

七、MQTT SSL不带证书连接示例
示例源码下载:

八、MQTT SSL带证书连接示例
示例源码下载:

九、常见问题Q&A
以下针对客户朋友们实际应用中的反馈,整理了MQTT应用中的常见问题:
MQTT/TCP/UDP的链接公用8路通道。
应用允许的情况下,建议使用Qos0;Qos1和Qos2会加重网络负担,4G网络还好,特别是2G网络,在网络拥堵和较差的情况下,数据传输的次数越多,掉线的概率就会越高。