From 50c6151c164d8d6bd4d052257c75ba424883fecb Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期五, 13 十月 2023 12:02:55 +0800
Subject: [PATCH] mqtt

---
 server/services/src/main/java/com/doumee/core/mqtt/config/MqttClientInit.java |   50 ++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 44 insertions(+), 6 deletions(-)

diff --git a/server/services/src/main/java/com/doumee/core/mqtt/config/MqttClientInit.java b/server/services/src/main/java/com/doumee/core/mqtt/config/MqttClientInit.java
index 06884d0..d71719c 100644
--- a/server/services/src/main/java/com/doumee/core/mqtt/config/MqttClientInit.java
+++ b/server/services/src/main/java/com/doumee/core/mqtt/config/MqttClientInit.java
@@ -10,14 +10,49 @@
 
 public class MqttClientInit {
         static MqttClient client;
+        static MqttClient subClient;
 
-        public static synchronized MqttClient getInstance(MqttConfig config,MqttPushCallback callBack){
+        public static synchronized MqttClient getInstance(MqttConfig config ){
             if(client !=null){
                 return  client;
             }
             try {
                 // host涓轰富鏈哄悕锛宑lientid鍗宠繛鎺QTT鐨勫鎴风ID锛屼竴鑸互鍞竴鏍囪瘑绗﹁〃绀猴紝MemoryPersistence璁剧疆clientid鐨勪繚瀛樺舰寮忥紝榛樿涓轰互鍐呭瓨淇濆瓨
-                client = new org.eclipse.paho.client.mqttv3.MqttClient(config.getHost(), config.getClientid()+ Constants.getUUID(),new MemoryPersistence());
+//                String clientId =config.getClientid()+ Constants.getUUID();
+                String clientId =config.getClientid();
+                client = new org.eclipse.paho.client.mqttv3.MqttClient(config.getHost(), clientId,new MemoryPersistence());
+                // MQTT鐨勮繛鎺ヨ缃�
+                MqttConnectOptions   options = new MqttConnectOptions();
+                // 璁剧疆鏄惁娓呯┖session,杩欓噷濡傛灉璁剧疆涓篺alse琛ㄧず鏈嶅姟鍣ㄤ細淇濈暀瀹㈡埛绔殑杩炴帴璁板綍锛岃缃负true琛ㄧず姣忔杩炴帴鍒版湇鍔″櫒閮戒互鏂扮殑韬唤杩炴帴
+                options.setCleanSession(false);
+                // 璁剧疆杩炴帴鐨勭敤鎴峰悕
+                options.setUserName(config.getUsername());
+                // 璁剧疆杩炴帴鐨勫瘑鐮�
+                options.setPassword(config.getPassword().toCharArray());
+                // 璁剧疆瓒呮椂鏃堕棿 鍗曚綅涓虹
+                options.setConnectionTimeout(10);
+                // 璁剧疆浼氳瘽蹇冭烦鏃堕棿 鍗曚綅涓虹 鏈嶅姟鍣ㄤ細姣忛殧1.5*20绉掔殑鏃堕棿鍚戝鎴风鍙戦�佷釜娑堟伅鍒ゆ柇瀹㈡埛绔槸鍚﹀湪绾匡紝浣嗚繖涓柟娉曞苟娌℃湁閲嶈繛鐨勬満鍒�
+                options.setKeepAliveInterval(20);
+                //璁剧疆鏂紑鍚庨噸鏂拌繛鎺�
+                options.setAutomaticReconnect(true);
+                MqttTopic topic = client.getTopic(clientId+"_close");
+                //閬楀槺
+                options.setWill(topic, "close".getBytes(), 1, true);
+                client.connect(options);
+            } catch (Exception e) {
+                e.printStackTrace();
+            }
+            return  client;
+        }
+        public static synchronized MqttClient getSubInstance(MqttConfig config,MqttPushCallback callBack){
+            if(subClient !=null){
+                return  subClient;
+            }
+            try {
+                // host涓轰富鏈哄悕锛宑lientid鍗宠繛鎺QTT鐨勫鎴风ID锛屼竴鑸互鍞竴鏍囪瘑绗﹁〃绀猴紝MemoryPersistence璁剧疆clientid鐨勪繚瀛樺舰寮忥紝榛樿涓轰互鍐呭瓨淇濆瓨
+//                String clientId =config.getClientid()+ Constants.getUUID();
+                String clientId =config.getSubclientid();
+                subClient = new org.eclipse.paho.client.mqttv3.MqttClient(config.getHost(), clientId,new MemoryPersistence());
                 // MQTT鐨勮繛鎺ヨ缃�
                 MqttConnectOptions   options = new MqttConnectOptions();
                 // 璁剧疆鏄惁娓呯┖session,杩欓噷濡傛灉璁剧疆涓篺alse琛ㄧず鏈嶅姟鍣ㄤ細淇濈暀瀹㈡埛绔殑杩炴帴璁板綍锛岃缃负true琛ㄧず姣忔杩炴帴鍒版湇鍔″櫒閮戒互鏂扮殑韬唤杩炴帴
@@ -31,18 +66,21 @@
                 // 璁剧疆浼氳瘽蹇冭烦鏃堕棿 鍗曚綅涓虹 鏈嶅姟鍣ㄤ細姣忛殧1.5*20绉掔殑鏃堕棿鍚戝鎴风鍙戦�佷釜娑堟伅鍒ゆ柇瀹㈡埛绔槸鍚﹀湪绾匡紝浣嗚繖涓柟娉曞苟娌℃湁閲嶈繛鐨勬満鍒�
                 options.setKeepAliveInterval(20);
                 // 璁剧疆鍥炶皟
-                client.setCallback(callBack);
+                subClient.setCallback(callBack);
                 //璁剧疆鏂紑鍚庨噸鏂拌繛鎺�
                 options.setAutomaticReconnect(true);
-                MqttTopic topic = client.getTopic(config.getClientid()+"_close");
+                MqttTopic topic = subClient.getTopic(clientId+"_close");
                 //閬楀槺
                 options.setWill(topic, "close".getBytes(), 1, true);
-                client.connect(options);
+                subClient.connect(options);
             } catch (Exception e) {
                 e.printStackTrace();
             }
-            return  client;
+            return  subClient;
         }
+
+
+
         public static synchronized void refreshClient() throws MqttException {
             if(client !=null){
                 boolean result = client.isConnected();

--
Gitblit v1.9.3