From 7991d16832df3d9f5c293d543ff8da40c36ef08d Mon Sep 17 00:00:00 2001 From: Administrator <1144154118@qq.com> Date: 星期六, 19 八月 2023 16:13:34 +0800 Subject: [PATCH] 巡检循环 --- ard-work/src/main/java/com/ruoyi/app/position/service/impl/AppPositionPush.java | 51 ++++++++++++++++++++++++++++++--------------------- 1 files changed, 30 insertions(+), 21 deletions(-) diff --git a/ard-work/src/main/java/com/ruoyi/app/position/service/impl/AppPositionPush.java b/ard-work/src/main/java/com/ruoyi/app/position/service/impl/AppPositionPush.java index 8e3f633..fc5f294 100644 --- a/ard-work/src/main/java/com/ruoyi/app/position/service/impl/AppPositionPush.java +++ b/ard-work/src/main/java/com/ruoyi/app/position/service/impl/AppPositionPush.java @@ -3,6 +3,7 @@ import com.ruoyi.app.position.domain.ArdAppPosition; import com.ruoyi.app.position.service.IArdAppPositionService; import com.ruoyi.common.core.domain.entity.SysUser; +import com.ruoyi.common.utils.StringUtils; import com.ruoyi.common.utils.spring.SpringUtils; import com.ruoyi.utils.websocket.util.WebSocketUtils; import com.ruoyi.system.service.ISysUserService; @@ -22,7 +23,7 @@ import java.util.stream.Collectors; /** - * @Description: app浣嶇疆鎺ㄩ�� + * @Description: app浣嶇疆鎺ㄩ�侊紙寮冪敤锛� * @ClassName: AppPositionPush * @Author: 鍒樿嫃涔� * @Date: 2023骞�07鏈�25鏃�16:07:04 @@ -33,42 +34,46 @@ //app浣嶇疆涓婁紶 public static final ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(20); public static final Map<Session, ScheduledFuture<?>> taskMap = new HashMap<>(); - public static final Map<String, List<ArdAppPosition>> defaultDataMap = new HashMap<>();//榛樿浼氳瘽鍙戦�佹暟鎹甿ap + public static final Map<String, List<ArdAppPosition>> initDataMap = new HashMap<>();//姣忎釜浼氳瘽鍒濆鍙戦�佹暟鎹甿ap // 鍒濆瀹氭椂浠诲姟锛屾牴鎹敤鎴疯缃殑棰戠巼瀹氭湡鎺ㄩ�佸疄鏃朵綅缃俊鎭� - public static void initPushTask(String userId,Session session, int pushFrequency) { - defaultDataMap.put(userId,getAppPositionList()); + public static void initPushTask(String userId, Session session, int pushFrequency) { + initDataMap.put(userId, getAppPositionList()); + List<ArdAppPosition> appPositionList = initDataMap.get(userId); + if (appPositionList.size() == 0) { + return; + } // 鍚姩鏂扮殑瀹氭椂浠诲姟 if (pushFrequency > 0) { scheduler.scheduleAtFixedRate(() -> { - List<ArdAppPosition> appPositionList = defaultDataMap.get(userId); - Map newMap = new HashMap<>(); - newMap.put("50000", appPositionList); - WebSocketUtils.sendMessage(session, newMap); + if (appPositionList.size() > 0) { + Map newMap = new HashMap<>(); + newMap.put("50000", appPositionList); + WebSocketUtils.sendMessage(session, newMap); + } }, 0, pushFrequency, TimeUnit.MILLISECONDS); } } // 鏂扮殑瀹氭椂浠诲姟锛屾牴鎹敤鎴疯缃殑棰戠巼瀹氭湡鎺ㄩ�佸疄鏃朵綅缃俊鎭� - public static void startLocationPushTask(String userId, Session session,String guideUserId, int pushFrequency) { + public static void startLocationPushTask(String userId, Session session, String guideUserId, int pushFrequency) { // 鍙栨秷涔嬪墠璁剧疆鐨勫畾鏃朵换鍔� stopLocationPushTask(session); // 鍚姩鏂扮殑瀹氭椂浠诲姟 if (pushFrequency > 0) { - ScheduledFuture<?> task = ScheduledFutureTask(session, userId,guideUserId, pushFrequency); - taskMap.put(session, task); // 瀛樺偍鏂扮殑瀹氭椂浠诲姟 - } - } - - public static ScheduledFuture<?> ScheduledFutureTask(Session session, String userId,String guideUserId, Integer pushFrequency) { - return scheduler.scheduleAtFixedRate(() -> { List<ArdAppPosition> appPositionList = getAppPositionList().stream() .filter(obj -> obj.getUserId().equals(guideUserId)) .collect(Collectors.toList()); - Map newMap = new HashMap<>(); - newMap.put("50000", appPositionList); - WebSocketUtils.sendMessage(session, newMap); - }, 0, pushFrequency, TimeUnit.MILLISECONDS); + if (appPositionList.size() == 0) { + return; + } + ScheduledFuture<?> task = scheduler.scheduleAtFixedRate(() -> { + Map newMap = new HashMap<>(); + newMap.put("50000", appPositionList); + WebSocketUtils.sendMessage(session, newMap); + }, 0, pushFrequency, TimeUnit.MILLISECONDS); + taskMap.put(session, task); // 瀛樺偍鏂扮殑瀹氭椂浠诲姟 + } } //鍙栨秷瀹氭椂浠诲姟 @@ -81,11 +86,15 @@ //鏌ヨ鎵�鏈塧pp鐢ㄦ埛鐨勪綅缃俊鎭� public static List<ArdAppPosition> getAppPositionList() { - List<ArdAppPosition>ArdAppPositions = new ArrayList<>(); + List<ArdAppPosition> ArdAppPositions = new ArrayList<>(); ISysUserService sysUserService = SpringUtils.getBean(ISysUserService.class); //鑾峰彇鎵�鏈塧pp鐢ㄦ埛 List<SysUser> list = sysUserService.selectAllAppUserList(new SysUser()); for (SysUser sysUser : list) { + if(StringUtils.isNull(sysUser.getAppOnlineState())) + {continue;} + if(sysUser.getAppOnlineState().equals("0")) + {continue; } IArdAppPositionService ardAppPositionService = SpringUtils.getBean(IArdAppPositionService.class); ArdAppPosition ardAppPosition = ardAppPositionService.selectLastArdAppPositionByUserId(sysUser.getUserId()); ArdAppPositions.add(ardAppPosition); -- Gitblit v1.9.3