From 9faa74e1912022dc6e54c3e93426946876b5d83a Mon Sep 17 00:00:00 2001
From: yangys <y_ys79@sina.com>
Date: 星期五, 25 十月 2024 10:49:13 +0800
Subject: [PATCH] 修改redistemplate的hashkey serializer,更方便客户端查看redis的数据

---
 collect/src/main/java/com/qianwen/mdc/collect/config/MqttConfig.java |   35 +++++++++++++++++++++++++++++------
 1 files changed, 29 insertions(+), 6 deletions(-)

diff --git a/collect/src/main/java/com/qianwen/mdc/collect/config/MqttConfig.java b/collect/src/main/java/com/qianwen/mdc/collect/config/MqttConfig.java
index c48f38f..e96c3f6 100644
--- a/collect/src/main/java/com/qianwen/mdc/collect/config/MqttConfig.java
+++ b/collect/src/main/java/com/qianwen/mdc/collect/config/MqttConfig.java
@@ -21,8 +21,10 @@
 import org.springframework.messaging.MessageChannel;
 import org.springframework.messaging.MessageHandler;
 
+import com.alibaba.fastjson.JSONObject;
 import com.qianwen.mdc.collect.service.DeviceStateFixPointService;
 import com.qianwen.mdc.collect.service.IOTMqttReceiveService;
+import com.qianwen.mdc.collect.service.WorkstationDatapointsService;
 import com.qianwen.mdc.collect.service.feedback.WorkstationFeedbackService;
 
 import cn.hutool.core.date.DateTime;
@@ -39,15 +41,20 @@
 
     @Value("${mqtt.password:}")
     private String mqttPassword;
-
 	@Autowired
 	private IOTMqttReceiveService recService;
 	@Autowired
     private DeviceStateFixPointService stateFixPointService;
-	
 	@Autowired
     private WorkstationFeedbackService workstationFeedbackService;
-	public static final String COLLECT_DATA_TOPIC = "forward/test";
+	
+	@Autowired
+    private WorkstationDatapointsService dpService;
+	/**
+	 * 鎺ユ敹鏁版嵁鐨刴qtt topic锛屽湪IOT骞冲彴閰嶇疆鐨�
+	 */
+	@Value("${mqtt.dataReceiveTopic:}")
+	public String COLLECT_DATA_TOPIC;
 	
 	/**
 	 * 鍙嶉鍒涘缓鐨則opic锛坢dc涓級锛屾湰搴旂敤鎺ユ敹骞跺鐞�
@@ -55,6 +62,11 @@
 	public static final String FEEDBACK_TOPIC = "mdc/feedback";
 	
 	public static final String WOCKSTATION_CREATE_TOPIC = "mdc/workstation-create";
+	
+	/**
+	 * 宸ヤ綅鏁版嵁鐐瑰彉鍖�
+	 */
+	private final String WORKSTATION_DATAPOINT_CHANGED_TOPIC = "mdc/workstation_datapoint_changed";
 	
 	@Bean
     public MqttPahoClientFactory mqttClientFactory() {
@@ -81,9 +93,12 @@
      */
     @Bean
     public MessageProducer inbound() {
+    	java.util.Random r = new java.util.Random();
+    	
+    	String clientId = "spring-boot-mqtt-client-inbound"+r.nextInt(1000);
         MqttPahoMessageDrivenChannelAdapter adapter =
-                new MqttPahoMessageDrivenChannelAdapter("spring-boot-mqtt-client-inbound",
-                        mqttClientFactory(), COLLECT_DATA_TOPIC, FEEDBACK_TOPIC,WOCKSTATION_CREATE_TOPIC);//鏈�鍚庝竴涓弬鏁板厑璁稿涓猼opic鍙傛暟
+                new MqttPahoMessageDrivenChannelAdapter(clientId,
+                        mqttClientFactory(), COLLECT_DATA_TOPIC, FEEDBACK_TOPIC,WOCKSTATION_CREATE_TOPIC,WORKSTATION_DATAPOINT_CHANGED_TOPIC);//鏈�鍚庝竴涓弬鏁板厑璁稿涓猼opic鍙傛暟
         adapter.setCompletionTimeout(5000);
         adapter.setConverter(new DefaultPahoMessageConverter());
         adapter.setQos(1);
@@ -113,7 +128,15 @@
         		logger.info("宸ヤ綅鍒涘缓鎺ユ敹娑堟伅={}",workstationId);
         		stateFixPointService.deviceStateFixPoint(DateTime.now(), Arrays.asList(workstationId));
         		recService.handle((String)message.getPayload());
-        	}else {//璁㈤槄浜嗗嚑涓猼opic灏变細鎺ユ敹鍒板嚑涓紝鍏朵粬鐨勪笉浼氳繘鏉�
+        	}else if(WORKSTATION_DATAPOINT_CHANGED_TOPIC.equals(topic)) {
+        		String payload = (String)message.getPayload();
+        		logger.info("宸ヤ綅appId鏄犲皠鍙樺寲娑堟伅={}",payload);
+        		//workstationAppMappingService.saveToCache();
+        		//娓呴櫎璇ュ伐浣嶇殑鏁版嵁鐐圭紦瀛�
+        		JSONObject payloadObj = JSONObject.parseObject(payload);
+        		//payloadObj.getLong("workstationId");
+        		dpService.datapointsCacheEvict(payloadObj.getString("appId"));
+        	} else {//璁㈤槄浜嗗嚑涓猼opic灏变細鎺ユ敹鍒板嚑涓紝鍏朵粬鐨勪笉浼氳繘鏉�
         		logger.warn("topic={},msg={},鏃犲搴旂殑澶勭悊鍣�",topic,message.getPayload());
         	}
         };

--
Gitblit v1.9.3