簡介
關聯(lián)文檔和使用工具:
- AT固件獲取
- AT指令手冊
材料準備
- [EVB_Air780EP(V)]開發(fā)板一套,包括天線SIM卡
- USB線
- PC電腦
- 串口調試工具(如果沒有準備,推薦可以使用llcom,進頁面按下Ctrl+F 搜索 AirM2M_780EP_LTE_AT 即可找到780EP模塊所使用的AT固件,推薦選用該固件名稱后面數(shù)字版本號最高的最新relase版本進行調試。
- 當前文檔示例使用AirM2M_780EP_V1007_LTE_AT版本固件

應用概述
4G模塊支持MQTT和MQTT SSl協(xié)議, MQTT應用的基本流程如下: 1、如果要支持SSL,配置SSL參數(shù) 2、通過TCP連接到MQTT服務器 3、發(fā)送MQTT CONNECT到服務器,打開會話連接 4、訂閱或者發(fā)布消息
示例
發(fā)布消息示例
先來看個正常情況下的AT命令序列,如果不理解AT命令含義,請自行參考AT手冊
AT+CPIN? +CPIN: READY //查詢sim卡是否正常 OK AT+CGATT? +CGATT: 1 //查詢是否附著上數(shù)據(jù)網絡,如果返回+CGATT: 0表示未附著上 OK AT+MCONFIG="866289037465624","user","password" OK AT+MIPSTART="lbsmqtt.airm2m.com","1884" OK CONNECT OK AT+MCONNECT=1,60 OK CONNACK OK AT+MSUB="mqtt/sub_topic",0 OK SUBACK AT+MPUB="mqtt/pub_topic",0,0,"publish 0 payload" OK AT+MPUB="mqtt/pub_topic",1,0,"publish 1 payload" OK PUBACK AT+MPUB="mqtt/pub_topic",2,0,"publish 2 payload" OK PUBREC PUBCOMP
發(fā)布消息示例演示效果


在這個過程中,注意事項如下:
1、發(fā)送MIPSTART命令后,收到OK僅僅表示4G模塊開始處理這條命令,并不表示TCP已經連接成功;只有收到CONNECT OK才是成功的應答(其余錯誤應答,參考AT手冊) 2、發(fā)送MCONNECT命令后,收到OK僅僅表示4G模塊開始處理這條命令,并不表示MQTT已經連接成功;只有收到CONNACK OK才是成功的應答(其余錯誤應答,參考AT手冊) 3、發(fā)送MSUB命令后,收到OK僅僅表示4G模塊開始處理這條命令,并不表示MQTT已經訂閱成功;只有收到SUBACK才是成功的應答(其余錯誤應答,參考AT手冊) 4、發(fā)送MPUB命令后,如果QOS不是0,則收到OK僅僅表示4G模塊開始處理這條命令,并不表示MQTT已經發(fā)布成功;只有收到PUBACK(QOS為1時)或者PUBCOMP(QOS為2時)才是成功的應答(其余錯誤應答,參考AT手冊)
接收消息示例
先來看下接收到訂閱消息時的AT命令處理序列,如果不理解AT命令含義,請自行參考AT手冊
AT+MCONFIG="866289037465624","user","password" OK AT+MIPSTART="lbsmqtt.airm2m.com","1884" OK CONNECT OK AT+MCONNECT=1,60 OK CONNACK OK AT+MSUB="mqtt/sub_topic",0 OK SUBACK AT+MPUB="mqtt/sub_topic",0,0,"123456" //在mqtt/sub_topic上收到訂閱消息,payload為123456 //默認是直接輸出收到的訂閱消息,不做緩存 +MSUB: "mqtt/sub_topic",6 byte,123456 //設置訂閱消息的處理模式,設置為緩存模式 //接下來收到訂閱消息時,會提示訂閱消息的緩存位置 AT+MQTTMSGSET=1 OK //在mqtt/sub_topic上收到一條訂閱消息,緩存到位置0 +MSUB: 0 //主動讀取緩存的所有訂閱消息 AT+MQTTMSGGET +MSUB:mqtt/sub_topic,6 byte,123456 OK //在mqtt/sub_topic上收到一條訂閱消息,緩存到位置0 +MSUB: 0 //在mqtt/sub_topic上收到一條訂閱消息,緩存到位置1 +MSUB: 1 //主動讀取緩存的所有訂閱消息 AT+MQTTMSGGET +MSUB:mqtt/sub_topic,6 byte,123456 +MSUB:mqtt/sub_topic,6 byte,123456 OK
接收消息演示效果


TCP被動斷開示例
先來看下連接被動斷開時的AT命令處理序列,如果不理解AT命令含義,請自行參考AT手冊
AT+MCONFIG="866289037465624","user","password" OK AT+MIPSTART="lbsmqtt.airm2m.com","1884" OK CONNECT OK AT+MCONNECT=1,60 OK CONNACK OK CLOSED //此處TCP連接被動斷開 AT+MIPCLOSE +CME ERROR: 767 //此處無論返回OK、ERROR還是CME ERROR,都直接跳過,不用做正確性判斷 AT+MCONFIG="866289037465624","user","password" OK AT+MIPSTART="lbsmqtt.airm2m.com","1884" OK CONNECT OK AT+MCONNECT=1,60 OK CONNACK OK
PDP被動去激活示例
先來看下PDP被動去激活時的AT命令處理序列,如果不理解AT命令含義,請自行參考AT手冊
AT+MCONFIG="866289037465624","user","password" OK AT+MIPSTART="lbsmqtt.airm2m.com","1884" OK CONNECT OK AT+MCONNECT=1,60 OK CONNACK OK +CGEV: NW PDN DEACT 1 //此處PDP被動去激活 AT+MIPCLOSE OK //此處無論返回OK、ERROR還是CME ERROR,都直接跳過,不用做正確性判斷 AT+MCONFIG="866289037465624","user","password" OK AT+MIPSTART="lbsmqtt.airm2m.com","1884" OK CONNECT OK AT+MCONNECT=1,60 OK CONNACK OK
常見問題
1、MQTT支持多連接嗎 目前MQTT僅支持單連接,不支持多連接 2、MQTT的遺囑如何使用 通過AT+MCONFIG命令可以設置遺囑的qos、retain標志、topic、payload;在如下幾種(包含但是又不僅限于如下情況)情況下,服務器會主動發(fā)布遺囑消息到訂閱的客戶端:
1、模塊和服務器通信異常(例如模塊突然關機、模塊進入了一個沒有網絡信號的環(huán)境等)超過1.5倍(一般是1.5倍,但不排除服務器可以修改這個時間)的 keep alive時間(可以通過AT+MCONNECT設置keep alive時間) 2、模塊主動執(zhí)行AT+MDISCONNECT或者AT+MIPCLOSE 曾經有用戶碰到過如下問題: 模塊設置了遺囑topic為/will_topic,遺囑payload為offline,keep alive時間為5分鐘,模塊關機后,等待2分鐘,在等待的2分鐘內,其他訂閱了/will_topic的客戶端沒有收到遺囑消息(這是正常的,因為還沒有到達1.5倍的keep alive時間),2分鐘后,模塊開機mqtt重連成功后,其他客戶端卻收到了遺囑消息,這是什么原因呢?這部分機制是服務器端設計的,和模塊無關,個人認為:服務器端仍然在維持2分鐘前的那個mqtt連接,現(xiàn)在模塊開機,用同樣的client id重連后,會斷開之前維護的相同client id的mqtt連接,斷開時,就發(fā)布了一次遺囑消息。那這種問題,如何解決呢?模塊可以在AT+MCONNECT返回CONNACK OK之后,通過AT+MPUB一個topic為/will_topic,payload為online的消息,這樣訂閱了遺囑topic的其他客戶端就會收到這個online消息
3、MQTT SSL如何使用 本文主要描述了基本流程和異常處理,對于MQTT SSL使用方法沒有做過多描述,這一部分,請自行參考AT手冊MQTT章節(jié)下《使用方法舉例》中的"SSL帶證書驗證流程"使用方法;支持的SSL參數(shù),請自行參考AT+SSLCFG命令說明
如果SSL的參數(shù)配置不變,則每次開機運行過程中,僅設置一次即可
4、重試多次PDP,MQTT應用一直連接失敗 如果重試多次PDP激活,PDP一直激活失敗,或者MQTT一直連接失敗,則嘗試使用如下手段恢復:
1、使用RESET引腳復位模塊 2、極端情況下,直接給模塊斷電,再上電,POWER KEY引腳拉低開機
5、MPUB命令中,payload包含"如何發(fā)送? 消息中內嵌的雙引號請用\22 表達;控制字符 \r(0x0D)請用\0D 表達;控制字符\n(0x0A) 請用\0A 表達 如果是 MCU 發(fā)消息,請用\\22,\\0D,\\0A 來 表達,即\需要轉義成\\
6、連接服務器失敗
- 檢查下模塊信號、網絡注冊、網絡附著、PDP激活狀態(tài)
- 檢查下SIM卡是否欠費
- 使用mqtt.fx,連接服務器確認一下是否可以連接成功,排除服務器故障
- 部分國外的開源項目提供免費的MQTT代理服務器,因為網絡的原因,國內存在嚴重的延遲或者丟包現(xiàn)象,導致程序運行出現(xiàn)問題,此現(xiàn)象在AT開發(fā)時影響嚴重
- 確認是不是域名解析失敗導致,可以通過AT+CDNSGIP=確認一下域名是否能正常解析(注意:該命令只有在執(zhí)行完at+cstt、at+ciicr、at+cifsr后才能正常工作),不能正常解析,可以通過AT+CDNSCFG=ip1,ip2設置域名解析服務器。
- 在 MIPSTART /SSLMIPSTART返 回 CONNECT OK后 才 能 發(fā) MCONNECT命令,而且要立即發(fā),否則會被服務器踢掉。
7、數(shù)據(jù)接收緩存問題
不緩存:通過AT+MQTTMSGSET=0設置;收到訂閱的publish報文后,立即通過AT口輸出主題、payload長度、payload內容,每個報文中支持的payload內容最長4100字節(jié)
內存緩存:通過AT+MQTTMSGSET=1設置;內存中有一個緩存表,一條消息最多4kb,最多支持緩存4條publish報文;收到訂閱的publish報文后,插入緩沖表中的空閑位置,然后通過AT口輸出存儲位置;緩存表滿之后,新收到的publish報文會覆蓋最舊的publish報文
注意:緩存表位于內存中,斷電或者重啟后,緩存表中的數(shù)據(jù)會被清空;建議收到數(shù)據(jù)時,通過AT+MQTTMSGGET及時讀取出來,以防緩沖區(qū)滿覆蓋丟失數(shù)據(jù)
8、數(shù)據(jù)發(fā)送問題 AT+MPUB最大publish 4100字節(jié),AT+MPUBEX長度取值范圍1-4100
-
開發(fā)板
+關注
關注
26文章
6154瀏覽量
114044 -
串口調試
+關注
關注
2文章
272瀏覽量
25476 -
MQTT
+關注
關注
5文章
726瀏覽量
24822 -
合宙通信
+關注
關注
0文章
148瀏覽量
2399
發(fā)布評論請先 登錄
Air780EP模塊 LuatOS開發(fā)-MQTT接入阿里云應用指南
MQTT應用看這篇!合宙Air780EP_LuatOS_MQTT應用指南
合宙Air780EP模塊開發(fā)常見問題——異常斷鏈篇
合宙Air780EP模塊——AT指令MQTT接入OneNET開發(fā)指南
Air780EP模塊AT開發(fā)FOTA遠程升級指南
Air780E/Air780EP/Air780EQ/Air201模塊遇到死機問題如何分析
Air780E/Air780EP/Air780EQ/Air201模塊遇到內存死機如何分析
Air780EP模塊 AT開發(fā)-MQTT接入OneNET移動物聯(lián)網平臺應用指南
合宙 Air780E/Air780EP/Air780EQ/Air201模塊遇到死機問題如何分析
合宙LuatOS開發(fā)板Core_Air780EP使用說明

780EP模塊 AT開發(fā)-MQTT應用指南
評論