From b2c928eac40c4b7f495f8164eeb59005219fa350 Mon Sep 17 00:00:00 2001 From: liurunyu <lry9898@163.com> Date: 星期三, 11 六月 2025 17:55:29 +0800 Subject: [PATCH] 1、MQTT协议,增加设备参数命令及相关数据; 2、完善上行数据值对象; 3、完善其他代码。 --- pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/mqtt/MqttManager.java | 65 ++++++++++++++++++++++++++++++-- 1 files changed, 60 insertions(+), 5 deletions(-) diff --git a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/mqtt/MqttManager.java b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/mqtt/MqttManager.java index 3c775b5..8085e91 100644 --- a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/mqtt/MqttManager.java +++ b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/mqtt/MqttManager.java @@ -1,9 +1,17 @@ package com.dy.rtuMw.server.mqtt; import com.dy.common.mw.channel.mqtt.MqttClientPool; +import com.dy.common.mw.protocol4Mqtt.MqttNotify; +import com.dy.common.mw.protocol4Mqtt.MqttNotifyInfo; +import com.dy.common.mw.protocol4Mqtt.status.DevOnLineInfo; +import com.dy.common.mw.protocol4Mqtt.status.DevRunInfo; +import com.dy.rtuMw.server.ServerProperties; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.eclipse.paho.client.mqttv3.MqttClient; + +import java.util.ArrayList; +import java.util.List; /** * @Author: liurunyu @@ -20,6 +28,8 @@ private MqttClientPool pool; + private List<MqttClient> subClients ; + private MqttManager(){ } @@ -33,13 +43,18 @@ this.configVo = configVo; } + /** + * 鍒涘缓杩炴帴姹� + 璁㈤槄涓婚 + * @throws Exception + */ public void start()throws Exception{ + subClients = new ArrayList<>(); String URL = "tcp://" + this.configVo.svIp + ":" + this.configVo.svPort; - this.pool = new MqttClientPool(URL, this.configVo.svUserName, this.configVo.svUserPassword, this.configVo.poolMaxSize); + this.pool = new MqttClientPool(URL, this.configVo.svUserName, this.configVo.svUserPassword, this.configVo.poolMaxSize, this.configVo.useMemoryPersistence); if(this.pool.isClose()){ throw new Exception("Mqtt杩炴帴姹犲垵濮嬪寲澶辫触"); } - MqttClient clientSub = null ; + MqttClient clientSub ; try { clientSub = pool.popClient();//鏂板垱寤轰竴涓狢lient鏃讹紝姝lient瀹為檯鍘昏繛鎺QTT鏈嶅姟鍣紝濡傛灉杩炴帴涓嶄笂锛屽氨浼氭姏鍑哄紓甯� }catch (Exception e){ @@ -48,12 +63,52 @@ if(clientSub == null || !clientSub.isConnected()){ throw new Exception("Mqtt杩炴帴姹犺幏寰楄闃呰繛鎺ヤ笉鍙敤"); } + subClients.add(clientSub) ; + // 璁㈤槄涓婚 for(int i = 0; i < this.configVo.subTopics.length; i++){ - clientSub.subscribe(this.configVo.subTopics[i], this.configVo.topicsQos[i], new MqttMessageListener()); + for(int j = 0 ; j < this.configVo.protocolAndDeviceIds.length; j++){ + clientSub.subscribe(ServerProperties.orgTag + "/" + + this.configVo.protocolAndDeviceIds[j] + "/" + + this.configVo.subTopics[i], + this.configVo.subTopicsQos[i], + //姣忎竴涓闃呬富棰橀兘鏈変竴涓狹qttMessageListener瀹炰緥 + new MqttMessageListener(new MqttNotify(){ + @Override + public void notify(String devId, MqttNotifyInfo... infos) { + if(devId != null && infos != null && infos.length > 0){ + for(MqttNotifyInfo info : infos){ + if(info instanceof DevOnLineInfo){ + DevOnLineInfo onLineSt = (DevOnLineInfo)info; + if(onLineSt.onLine != null && onLineSt.onLine.booleanValue()){ + DevStatusDealer.onLine(devId, ((DevOnLineInfo)info).protocol); + }else{ + DevStatusDealer.offLine(devId); + } + } else if(info instanceof DevRunInfo){ + DevStatusDealer.setStatus(devId, (DevRunInfo)info); + } + } + } + } + }) + ); + } } } public void stop()throws Exception{ + if(subClients != null && subClients.size() > 0){ + for (MqttClient client : subClients) { + if(client != null && client.isConnected()){ + try{ + client.disconnect(); + client.close(); + }catch (Exception e){ + e.printStackTrace(); + } + } + } + } if(this.pool != null){ // 鍏抽棴杩炴帴姹� this.pool.close(); @@ -69,12 +124,12 @@ } public void publishMsg(MqttClient client, String topic, byte[] msg) throws Exception{ - client.publish(topic, msg, this.configVo.publishQos, false); + client.publish(topic, msg, this.configVo.pubTopicQos, false); } public void publishMsg(MqttClient client, String topic, String msg) throws Exception{ byte[] bs = msg.getBytes("UTF-8") ; - client.publish(topic, bs, this.configVo.publishQos, false); + client.publish(topic, bs, this.configVo.pubTopicQos, false); } public boolean poolIsClose(){ -- Gitblit v1.8.0