您好,登錄后才能下訂單哦!
本篇內容主要講解“如何二次封裝MQTT開源組件moquette”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“如何二次封裝MQTT開源組件moquette”吧!
moquette是一款開源的消息代理,整個系統基于java開發,以netty為基礎完整實現了MQTT協議的。
單純靠moquette直接使用到項目上確實有些不太好用,通過需求做一定量的封裝使用更方便。
下面開始對moquette的封裝做一定的記錄
1.封裝主要涉及內容有跟隨SpringBoot啟動同時啟動mqtt服務器
2.封裝服務器對客戶端發送消息功能、封裝判斷客戶端是否在線、封裝服務器向設備發送消息并獲取返回值
config: 配置類文件
handler: 客戶端連接和消息處理類文件
server: 封裝了moquette的消息發送類
utils: 需要使用到的工具類
mqtt: mqtt服務的端口、賬號、秘密等配置信息
MqttBrokerConfiguration.java:創建moquette的Server在Spring自動注入對象
MqttBrokerRunConfiguration.java:mqtt服務隨SpringBoot項目啟動配置類
MqttCustomConfig.java:管理mqtt需要使用到的Topic
下面2個類都是處理客戶端的連接、斷開連接、接收客戶端消息等事件功能,主要區分不同的使用場景,主要都是實現了moquette提供的 AbstractInterceptHandler類
1.接收客戶端數據API:實現AbstractInterceptHandler類重寫onPublish函數就能通過onPublish函數接收客戶端的消息。2.判斷客戶端是否在線APIMqttServer.isOnline(clientId)3.發送消息到客戶端此方法適用設備提供了接口與參數類型數量等消息發送,并且會獲得對應的返回值,但是需要客戶端處理完數據之后再向服務器推送一條特定topic的消息,雙方約定好消息topicMqttServer.luatInvoke(clientId,apiTag,params)clientId:客戶端IDapiTag:客戶端接口名稱params:參數此方法適用于客戶端沒提供接口等消息發送,并且會獲得對應的返回值,但是需要客戶端處理完數據之后再向服務器推送一條特定topic的消息,雙方約定好消息topicMqttServer.pubAndSub(clientId,rrpcCmd,topicPub,topicSub)clientId:客戶端IDrrpcCmd:發送的消息topicPub:客戶端訂閱的topictopicSub:客戶端返回消息發送的topic
MQTT客戶端通過TCP協議連接服務器,向服務器發送消息,服務器的AbstractInterceptHandler.onPublish(msg)接口能接收任何從各個客戶端發送的消息。同時客戶端需要監聽回調函數,保證接收到服務器的消息。MQTT服務器向客戶端發送消息之后有8秒鐘時間等待客戶端發布指定topic消息,服務器接收到的時候把它當成一個返回值處理
封裝后的代碼路徑:https://gitee.com/winfongs/mqtt
到此,相信大家對“如何二次封裝MQTT開源組件moquette”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。