From fb8a5d483bcaad8d0c4a9ac5842291eef694eb05 Mon Sep 17 00:00:00 2001 From: 648540858 <648540858@qq.com> Date: Wed, 11 Jan 2023 11:33:01 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E5=A4=8Dredis=E6=9F=A5=E8=AF=A2?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../session/VideoStreamSessionManager.java | 2 +- .../storager/impl/RedisCatchStorageImpl.java | 18 +++++++++--------- .../iot/vmp/utils/redis/RedisUtil.java | 17 ++--------------- 3 files changed, 12 insertions(+), 25 deletions(-) diff --git a/src/main/java/com/genersoft/iot/vmp/gb28181/session/VideoStreamSessionManager.java b/src/main/java/com/genersoft/iot/vmp/gb28181/session/VideoStreamSessionManager.java index 9d2890e6..d9b9cc5a 100644 --- a/src/main/java/com/genersoft/iot/vmp/gb28181/session/VideoStreamSessionManager.java +++ b/src/main/java/com/genersoft/iot/vmp/gb28181/session/VideoStreamSessionManager.java @@ -70,7 +70,7 @@ public class VideoStreamSessionManager { stream ="*"; } String key = VideoManagerConstants.MEDIA_TRANSACTION_USED_PREFIX + userSetting.getServerId() + "_" + deviceId + "_" + channelId + "_" + callId+ "_" + stream; - List scanResult = RedisUtil.scan(key, 1); + List scanResult = RedisUtil.scan(key); if (scanResult.size() == 0) { return null; } diff --git a/src/main/java/com/genersoft/iot/vmp/storager/impl/RedisCatchStorageImpl.java b/src/main/java/com/genersoft/iot/vmp/storager/impl/RedisCatchStorageImpl.java index 393fbf1a..8cf5293b 100644 --- a/src/main/java/com/genersoft/iot/vmp/storager/impl/RedisCatchStorageImpl.java +++ b/src/main/java/com/genersoft/iot/vmp/storager/impl/RedisCatchStorageImpl.java @@ -75,7 +75,7 @@ public class RedisCatchStorageImpl implements IRedisCatchStorage { @Override public void resetAllSN() { String scanKey = VideoManagerConstants.SIP_SN_PREFIX + userSetting.getServerId() + "_*"; - List keys = RedisUtil.scan(scanKey, null); + List keys = RedisUtil.scan(scanKey); for (Object o : keys) { String key = (String) o; RedisUtil.set(key, 1); @@ -129,7 +129,7 @@ public class RedisCatchStorageImpl implements IRedisCatchStorage { } @Override public StreamInfo queryPlayByStreamId(String streamId) { - List playLeys = RedisUtil.scan(String.format("%S_%s_*_%s_*", VideoManagerConstants.PLAYER_PREFIX, userSetting.getServerId(), streamId), 1); + List playLeys = RedisUtil.scan(String.format("%S_%s_*_%s_*", VideoManagerConstants.PLAYER_PREFIX, userSetting.getServerId(), streamId)); if (playLeys == null || playLeys.size() == 0) { return null; } @@ -141,7 +141,7 @@ public class RedisCatchStorageImpl implements IRedisCatchStorage { List playLeys = RedisUtil.scan(String.format("%S_%s_*_*_%s_%s", VideoManagerConstants.PLAYER_PREFIX, userSetting.getServerId(), deviceId, - channelId), 1); + channelId)); if (playLeys == null || playLeys.size() == 0) { return null; } @@ -278,7 +278,7 @@ public class RedisCatchStorageImpl implements IRedisCatchStorage { stream, callId ); - List streamInfoScan = RedisUtil.scan(key, 1); + List streamInfoScan = RedisUtil.scan(key); if (streamInfoScan.size() > 0) { return (StreamInfo) RedisUtil.get((String) streamInfoScan.get(0)); }else { @@ -310,7 +310,7 @@ public class RedisCatchStorageImpl implements IRedisCatchStorage { stream, callId ); - List streamInfoScan = RedisUtil.scan(key, 1); + List streamInfoScan = RedisUtil.scan(key); return (String) streamInfoScan.get(0); } @@ -399,7 +399,7 @@ public class RedisCatchStorageImpl implements IRedisCatchStorage { + channelId + "_" + streamId + "_" + callId; - List scan = RedisUtil.scan(key, 1); + List scan = RedisUtil.scan(key); if (scan.size() > 0) { return (SendRtpItem)RedisUtil.get((String)scan.get(0)); }else { @@ -521,7 +521,7 @@ public class RedisCatchStorageImpl implements IRedisCatchStorage { String key = VideoManagerConstants.PLATFORM_SEND_RTP_INFO_PREFIX + userSetting.getServerId() + "_*_*_" + channelId + "*_" + "*_"; - List RtpStreams = RedisUtil.scan(key, 1); + List RtpStreams = RedisUtil.scan(key); if (RtpStreams.size() > 0) { return true; } else { @@ -613,7 +613,7 @@ public class RedisCatchStorageImpl implements IRedisCatchStorage { stream, callId ); - List streamInfoScan = RedisUtil.scan(key, 1); + List streamInfoScan = RedisUtil.scan(key); if (streamInfoScan.size() > 0) { return (StreamInfo) RedisUtil.get((String) streamInfoScan.get(0)); }else { @@ -732,7 +732,7 @@ public class RedisCatchStorageImpl implements IRedisCatchStorage { String scanKey = VideoManagerConstants.WVP_SERVER_STREAM_PREFIX + userSetting.getServerId() + "_*_" + app + "_" + streamId + "_" + mediaServerId; OnStreamChangedHookParam result = null; - List keys = RedisUtil.scan(scanKey, 1); + List keys = RedisUtil.scan(scanKey); if (keys.size() > 0) { String key = (String) keys.get(0); result = (OnStreamChangedHookParam)RedisUtil.get(key); diff --git a/src/main/java/com/genersoft/iot/vmp/utils/redis/RedisUtil.java b/src/main/java/com/genersoft/iot/vmp/utils/redis/RedisUtil.java index c5be52c0..50152cda 100644 --- a/src/main/java/com/genersoft/iot/vmp/utils/redis/RedisUtil.java +++ b/src/main/java/com/genersoft/iot/vmp/utils/redis/RedisUtil.java @@ -864,16 +864,12 @@ public class RedisUtil { * @param query 查询参数 * @return */ - public static List scan(String query, Integer count) { + public static List scan(String query) { if (redisTemplate == null) { redisTemplate = SpringBeanFactory.getBean("redisTemplate"); } Set resultKeys = (Set) redisTemplate.execute((RedisCallback>) connection -> { - ScanOptions.ScanOptionsBuilder match = ScanOptions.scanOptions().match("*" + query + "*"); - if (count != null) { - match.count(count); - } - ScanOptions scanOptions = match.build(); + ScanOptions scanOptions = ScanOptions.scanOptions().match("*" + query + "*").count(1000).build(); Cursor scan = connection.scan(scanOptions); Set keys = new HashSet<>(); while (scan.hasNext()) { @@ -886,15 +882,6 @@ public class RedisUtil { return new ArrayList<>(resultKeys); } - /** - * 模糊查询 - * @param query 查询参数 - * @return - */ - public static List scan(String query) { - return scan(query, null); - } - // ============================== 消息发送与订阅 ============================== public static void convertAndSend(String channel, JSONObject msg) { if (redisTemplate == null) {