spring redis 如何實現模糊查找key
spring redis 模糊查找key
用法
Set<String> keySet = stringRedisTemplate.keys("keyprefix:"+"*");
- 需要使用StringRedisTemplate,或自定義keySerializer為StringRedisSerializer的redisTemplate
- redis裡模糊查詢key允許使用的通配符:
* 任意多個字符
? 單個字符
[] 括號內的某1個字符
源碼
org.springframework.data.redis.core.RedisTemplate public Set<K> keys(K pattern) { byte[] rawKey = rawKey(pattern); Set<byte[]> rawKeys = execute(connection -> connection.keys(rawKey), true); return keySerializer != null ? SerializationUtils.deserialize(rawKeys, keySerializer) : (Set<K>) rawKeys; }
改善
- Redis2.8以後可以使用scan獲取key
- 基於遊標迭代分次遍歷key,不會一次性掃描所有key導致性能消耗過大,減少服務器阻塞
可以通過count參數設置掃描的范圍
Set<String> keys = new LinkedHashSet<>(); stringRedisTemplate.execute((RedisConnection connection) -> { try (Cursor<byte[]> cursor = connection.scan( ScanOptions.scanOptions() .count(Long.MAX_VALUE) .match(pattern) .build() )) { cursor.forEachRemaining(item -> { keys.add(RedisSerializer.string().deserialize(item)); }); return null; } catch (Exception e) { throw new RuntimeException(e); } });
Reids SCAN命令官方文檔
redis-redisTemplate模糊匹配刪除
String key = "noteUserListenedPoi:*"; redisTemplate.delete(key); LOGGER.info("redis中用戶收聽歷史被清空");
後來測試發現模糊查詢是可以用的, 刪除改成
Set<String> keys = redisTemplate.keys("noteUserListenedPoi:" + "*"); redisTemplate.delete(keys); LOGGER.info("{}, redis中用戶收聽歷史被清空"
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- 解決RedisTemplate的key默認序列化器的問題
- 淺談Redis的keys命令到底有多慢
- redis keys與scan命令的區別說明
- php redis的scan用法實例分析
- Redis分佈式非公平鎖的使用