wan_multilink_mqtt.lua 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. -- 自动低功耗, 轻休眠模式
  2. -- Air780E、Air780EP支持uart唤醒和网络数据下发唤醒, 但需要断开USB,或者pm.power(pm.USB, false) 但这样也看不到日志了
  3. -- pm.request(pm.LIGHT)
  4. -- 根据自己的服务器修改以下参数
  5. local mqtt_host = "lbsmqtt.airm2m.com"
  6. local mqtt_port = 1884
  7. local mqtt_isssl = false
  8. local client1_id = "abc"
  9. local client2_id = "abc2"
  10. local user_name = "user"
  11. local password = "password"
  12. --第一个mqtt链接
  13. local mqttc1 = nil
  14. local pub_topic_client = "/luatos/pub/client1/"
  15. local sub_topic_client = "/luatos/sub/client1/"
  16. --第二个mqtt链接
  17. local mqttc2 = nil
  18. local pub_topic_client2 = "/luatos/pub/client2/"
  19. local sub_topic_client2 = "/luatos/sub/client2/"
  20. local device_id = mobile.imei()
  21. sys.taskInit(function()
  22. -- 等待联网
  23. sys.waitUntil("CH390_IP_READY")
  24. log.info("CH390 联网成功,开始测试")
  25. socket.dft(socket.LWIP_ETH) -- 配置默认网卡为CH390
  26. -- 如果自带的DNS不好用,可以用下面的公用DNS,但是一定是要在CH390联网成功后使用
  27. -- socket.setDNS(socket.LWIP_ETH,1,"223.5.5.5")
  28. -- socket.setDNS(nil,1,"114.114.114.114")
  29. -- local ret, device_id = sys.waitUntil("net_ready")
  30. -- 下面的是mqtt的参数均可自行修改
  31. -- client1_id = device_id
  32. pub_topic_client = pub_topic_client .. device_id
  33. sub_topic_client = sub_topic_client .. device_id
  34. -- 打印一下上报(pub)和下发(sub)的topic名称
  35. -- 上报: 设备 ---> 服务器
  36. -- 下发: 设备 <--- 服务器
  37. -- 可使用mqtt.x等客户端进行调试
  38. log.info("mqtt", "pub", pub_topic_client)
  39. log.info("mqtt", "sub", sub_topic_client)
  40. if mqtt == nil then
  41. while 1 do
  42. sys.wait(1000)
  43. log.info("bsp", "本bsp未适配mqtt库, 请查证")
  44. end
  45. end
  46. -------------------------------------
  47. -------- MQTT 演示代码 --------------
  48. -------------------------------------
  49. mqttc1 = mqtt.create(nil, mqtt_host, mqtt_port, mqtt_isssl)
  50. mqttc1:auth(client1_id, user_name, password) -- client_id必填,其余选填
  51. -- mqttc1:keepalive(240) -- 默认值240s
  52. mqttc1:autoreconn(true, 3000) -- 自动重连机制
  53. mqttc1:on(function(mqtt_client, event, data, payload)
  54. -- 用户自定义代码
  55. log.info("mqtt", "event", event, mqtt_client, data, payload)
  56. if event == "conack" then
  57. -- 联上了
  58. sys.publish("mqtt_conack")
  59. mqtt_client:subscribe(sub_topic_client) -- 单主题订阅
  60. -- mqtt_client:subscribe({[topic1]=1,[topic2]=1,[topic3]=1})--多主题订阅
  61. elseif event == "recv" then
  62. log.info("mqtt", "downlink", "topic", data, "payload", payload)
  63. sys.publish("mqtt_payload", data, payload)
  64. elseif event == "sent" then
  65. -- log.info("mqtt", "sent", "pkgid", data)
  66. -- elseif event == "disconnect" then
  67. -- 非自动重连时,按需重启mqttc
  68. -- mqtt_client:connect()
  69. end
  70. end)
  71. -- mqttc自动处理重连, 除非自行关闭
  72. mqttc1:connect()
  73. sys.waitUntil("mqtt_conack")
  74. while true do
  75. -- 演示等待其他task发送过来的上报信息
  76. local ret, topic, data, qos = sys.waitUntil("mqtt_pub", 300000)
  77. if ret then
  78. -- 提供关闭本while循环的途径, 不需要可以注释掉
  79. if topic == "close" then
  80. break
  81. end
  82. mqttc1:publish(topic, data, qos)
  83. end
  84. -- 如果没有其他task上报, 可以写个空等待
  85. -- sys.wait(60000000)
  86. end
  87. mqttc1:close()
  88. mqttc1 = nil
  89. end)
  90. -- 这里演示在另一个task里上报数据, 会定时上报数据,不需要就注释掉
  91. sys.taskInit(function()
  92. sys.wait(3000)
  93. local data = "123,"
  94. local qos = 1 -- QOS0不带puback, QOS1是带puback的
  95. while true do
  96. sys.wait(3000)
  97. if mqttc1 and mqttc1:ready() then
  98. local pkgid = mqttc1:publish(pub_topic_client, data .. os.date(), qos)
  99. -- local pkgid = mqttc1:publish(topic2, data, qos)
  100. -- local pkgid = mqttc1:publish(topic3, data, qos)
  101. end
  102. end
  103. end)
  104. -- mqtt多链接示例
  105. sys.taskInit(function()
  106. -- 等待联网
  107. local ret, device_id = sys.waitUntil("net_ready")
  108. -- 下面的是mqtt的参数均可自行修改
  109. client2_id = device_id .. "2"
  110. pub_topic_client2 = pub_topic_client2 .. device_id
  111. sub_topic_client2 = sub_topic_client2 .. device_id
  112. -- 打印一下上报(pub)和下发(sub)的topic名称
  113. -- 上报: 设备 ---> 服务器
  114. -- 下发: 设备 <--- 服务器
  115. -- 可使用mqtt.x等客户端进行调试
  116. log.info("mqtt", "pub", pub_topic_client2)
  117. log.info("mqtt", "sub", sub_topic_client2)
  118. -- 打印一下支持的加密套件, 通常来说, 固件已包含常见的99%的加密套件
  119. -- if crypto.cipher_suites then
  120. -- log.info("cipher", "suites", json.encode(crypto.cipher_suites()))
  121. -- end
  122. if mqtt == nil then
  123. while 1 do
  124. sys.wait(1000)
  125. log.info("bsp", "本bsp未适配mqtt库, 请查证")
  126. end
  127. end
  128. -------------------------------------
  129. -------- MQTT 演示代码 --------------
  130. -------------------------------------
  131. mqttc2 = mqtt.create(nil, mqtt_host, mqtt_port, mqtt_isssl)
  132. mqttc2:auth(client2_id, user_name, password) -- client_id必填,其余选填
  133. -- mqttc2:keepalive(240) -- 默认值240s
  134. mqttc2:autoreconn(true, 3000) -- 自动重连机制
  135. mqttc2:on(function(mqtt_client, event, data, payload)
  136. -- 用户自定义代码
  137. log.info("mqtt", "event", event, mqtt_client, data, payload)
  138. if event == "conack" then
  139. -- 联上了
  140. sys.publish("mqtt_conack")
  141. mqtt_client:subscribe(sub_topic_client2) -- 单主题订阅
  142. -- mqtt_client:subscribe({[topic1]=1,[topic2]=1,[topic3]=1})--多主题订阅
  143. elseif event == "recv" then
  144. log.info("mqtt", "downlink", "topic", data, "payload", payload)
  145. sys.publish("mqtt_payload", data, payload)
  146. elseif event == "sent" then
  147. -- log.info("mqtt", "sent", "pkgid", data)
  148. -- elseif event == "disconnect" then
  149. -- 非自动重连时,按需重启mqttc
  150. -- mqtt_client:connect()
  151. end
  152. end)
  153. -- mqttc自动处理重连, 除非自行关闭
  154. mqttc2:connect()
  155. sys.waitUntil("mqtt_conack")
  156. while true do
  157. -- 演示等待其他task发送过来的上报信息
  158. local ret, topic, data, qos = sys.waitUntil("mqtt_pub", 300000)
  159. if ret then
  160. -- 提供关闭本while循环的途径, 不需要可以注释掉
  161. if topic == "close" then
  162. break
  163. end
  164. mqttc2:publish(topic, data, qos)
  165. end
  166. -- 如果没有其他task上报, 可以写个空等待
  167. -- sys.wait(60000000)
  168. end
  169. mqttc2:close()
  170. mqttc2 = nil
  171. end)
  172. -- 这里演示在另一个task里上报数据, 会定时上报数据,不需要就注释掉
  173. sys.taskInit(function()
  174. sys.wait(3000)
  175. local data = "123,"
  176. local qos = 1 -- QOS0不带puback, QOS1是带puback的
  177. while true do
  178. sys.wait(3000)
  179. if mqttc2 and mqttc2:ready() then
  180. local pkgid = mqttc2:publish(pub_topic_client2, data .. os.date(), qos)
  181. -- local pkgid = mqttc2:publish(topic2, data, qos)
  182. -- local pkgid = mqttc2:publish(topic3, data, qos)
  183. end
  184. end
  185. end)
  186. sys.taskInit(function()
  187. while true do
  188. sys.wait(3000)
  189. log.info("lua", rtos.meminfo())
  190. log.info("sys", rtos.meminfo("sys"))
  191. end
  192. end)
  193. -- 用户代码已结束---------------------------------------------
  194. -- 结尾总是这一句
  195. sys.run()
  196. -- sys.run()之后后面不要加任何语句!!!!!