From 51396d6ed0747b1e909056ed72108b6b0c811667 Mon Sep 17 00:00:00 2001
From: fuliqi <fuliqi@qq.com>
Date: 星期三, 13 十一月 2024 11:00:58 +0800
Subject: [PATCH] 离线检测优化

---
 ycl-server/src/main/java/com/ycl/task/UYTask.java |   63 +++++++++++++++++--------------
 1 files changed, 35 insertions(+), 28 deletions(-)

diff --git a/ycl-server/src/main/java/com/ycl/task/UYTask.java b/ycl-server/src/main/java/com/ycl/task/UYTask.java
index 0256642..f788121 100644
--- a/ycl-server/src/main/java/com/ycl/task/UYTask.java
+++ b/ycl-server/src/main/java/com/ycl/task/UYTask.java
@@ -195,7 +195,7 @@
         for (TMonitorResult result : monitorList) {
             TMonitorResult mongoData = mongoMap.get(result.getNo());
             if(mongoData!=null){
-                result.setOffLineTime(mongoData.getOffLineTime());
+                result.setOffLineTimeStr(mongoData.getOffLineTimeStr());
             }
         }
         List<TMonitorResult> dataList = new ArrayList<>(48);
@@ -206,37 +206,44 @@
                             return thread.call(); // 鍋囪 OnlineCheckThread 瀹炵幇浜� Callable 鎺ュ彛
                         }, executorService)
                         .orTimeout(60, TimeUnit.SECONDS)
-                        //鍑虹幇寮傚父
                         .exceptionally(ex -> {
                             if (ex instanceof TimeoutException) {
                                 log.error("浠诲姟鎵ц瓒呮椂:"+monitor.getIp());
                             } else {
-                                log.error("浠诲姟鎵ц寮傚父:"+monitor.getIp() + ex);
+                                log.error("浠诲姟鎵ц寮傚父:"+monitor.getIp() +ex);
+                                ex.printStackTrace();
                             }
-                            int checkTimes = 1;
-                            int offLineTimes = 1;
-                            Map<String, Object> map = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstant.ONLINE_KEY, monitor.getIp());
-                            if (!CollectionUtils.isEmpty(map)) {
-                                checkTimes = (Integer) map.get("checkTimes") + 1;
-                                offLineTimes = (Integer) map.get("offLineTimes");
-                            }
-                            monitor.setPingOnline(Boolean.FALSE);
-                            monitor.setCheckCount(checkTimes);
-                            monitor.setOffLineCount(offLineTimes);
-                            List<Date> offLineTime = monitor.getOffLineTime();
-                            if(CollectionUtils.isEmpty(offLineTime)) offLineTime = new ArrayList<>();
-                            offLineTime.add(new Date());
-                            monitor.setOffLineTime(offLineTime);
-                            if (monitor.getOffLineCount() >= time) {
-                                WorkOrder workOrder = new WorkOrder();
-                                workOrder.setSerialNumber(monitor.getNo());
-                                List<String> errList = new ArrayList<>();
-                                errList.add(ErrorType.DEVICE_OFFLINE.getValue());
-                                workOrder.setErrorTypeList(errList);
-                                workOrder.setStatus(WorkOrderStatusEnum.DISTRIBUTED);
-                                monitor.setWorkOrder(workOrder);
-                            }
-                            return monitor; // 杩斿洖澶辫触鐨勭粨鏋�
+                            return null;
+//                            int checkTimes = 1;
+//                            int offLineTimes = 1;
+//                            Map<String, Object> map = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstant.ONLINE_KEY, monitor.getNo());
+//                            if (!CollectionUtils.isEmpty(map)) {
+//                                checkTimes = (Integer) map.get("checkTimes") + 1;
+//                                offLineTimes = (Integer) map.get("offLineTimes");
+//                            }else {
+//                                map = new HashMap<>();
+//                            }
+//                            monitor.setPingOnline(Boolean.FALSE);
+//                            monitor.setCheckCount(checkTimes);
+//                            monitor.setOffLineCount(offLineTimes);
+//                            List<Date> offLineTime = monitor.getOffLineTime();
+//                            if(CollectionUtils.isEmpty(offLineTime)) offLineTime = new ArrayList<>();
+//                            offLineTime.add(new Date());
+//                            monitor.setOffLineTime(offLineTime);
+//                            if (monitor.getOffLineCount() >= time) {
+//                                WorkOrder workOrder = new WorkOrder();
+//                                workOrder.setSerialNumber(monitor.getNo());
+//                                List<String> errList = new ArrayList<>();
+//                                errList.add(ErrorType.DEVICE_OFFLINE.getValue());
+//                                workOrder.setErrorTypeList(errList);
+//                                workOrder.setStatus(WorkOrderStatusEnum.DISTRIBUTED);
+//                                monitor.setWorkOrder(workOrder);
+//                            }
+//                            map.put("checkTimes", checkTimes);
+//                            map.put("offLineTimes", offLineTimes);
+//                            redisTemplate.opsForHash().put(RedisConstant.ONLINE_KEY, monitor.getNo(), map);
+//                            return monitor; // 杩斿洖澶辫触鐨勭粨鏋�
+
                         }))
                 .collect(Collectors.toList());
 
@@ -247,7 +254,7 @@
         try {
             allOf.get(60, TimeUnit.SECONDS); // 缁欎簣棰濆鐨�5绉掓潵鏀堕泦缁撴灉
         } catch (TimeoutException e) {
-            log.warn("閮ㄥ垎浠诲姟鏈湪鎸囧畾鏃堕棿鍐呭畬鎴�");
+            log.error("閮ㄥ垎浠诲姟鏈湪鎸囧畾鏃堕棿鍐呭畬鎴�");
         } catch (Exception e2){
             log.error("鏁版嵁鏀堕泦寮傚父"+e2);
         }

--
Gitblit v1.8.0