Java Redis获取key的方式

方案一:keys *

keys的模糊匹配功能很方便也很强大,但是在生产环境需要慎用!

开发中使用keys的模糊匹配却发现redis的CPU使用率极高,所以公司的redis生产环境将keys命令禁用了!redis是单线程,会被堵塞

方案二:scan

SCAN 命令是一个基于游标的迭代器,SCAN命令每次被调用之后,都会向用户返回一个新的游标,用户在下次选代时需要使用这个新游标作为SCAN命令的游标参数,以此来延续之前的选代过程。

代码实现

scan方法

typescript 复制代码
/**
 * 扫描主键,建议使用
 * @param patten
 * @return
 */
public Set<String> scan(String patten){
    Set<String> keys = stringRedisTemplate.execute((RedisCallback<Set<String>>) connection -> {
        Set<String> result = new HashSet<>();
        try (Cursor<byte[]> cursor = connection.scan(new ScanOptions.ScanOptionsBuilder()
                .match(patten).count(10000).build())) {
            while (cursor.hasNext()) {
                result.add(new String(cursor.next()));
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
        return result;
    });
    return  keys;
}

使用

匹配"future_*"开头的所有key

typescript 复制代码
@Test
public void keys(){
    Set<String> scan = cacheService.scan("future_*");
    System.out.println(scan);
}
相关推荐
Victor35637 分钟前
MongoDB(101)如何处理MongoDB中的慢查询?
后端
Victor35640 分钟前
MongoDB(102)如何处理MongoDB中的数据冲突?
后端
IT_陈寒40 分钟前
SpringBoot自动配置的坑差点没把我埋了
前端·人工智能·后端
码农阿豪1 小时前
群晖部署Moodist配内网穿透穿透,把白噪音服务搬到公网上
数据库·spring boot·后端
0xDevNull1 小时前
Spring中统一异常处理详细教程
java·开发语言·后端
abcefg_h1 小时前
GORM——基础介绍与CRUD
开发语言·后端·golang
Undoom2 小时前
告别“复读机”:深度拆解星云 SDK 如何破解数字人实时交互的“不可能三角”
后端
weixin_408099672 小时前
Lua请求文字识别ocr api
图像处理·人工智能·后端·ocr·lua·api·文字识别
zshs0002 小时前
重读《凤凰架构》,从分布式演进史看技术选型的本质
分布式·后端·架构
GetcharZp12 小时前
比 Zap 还要快?Go 社区高性能日志神器 Zerolog 落地实践指南
后端