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);
}
相关推荐
Maiko Star5 分钟前
跑通第一个Spring AI 应用
java·后端·spring·springai
木易 士心10 分钟前
云数据库 Clouder 认证:SQL 基础开发与应用题型分析
数据库·后端·sql·oracle
Java女侠_9年实战11 分钟前
==与equals()混用陷阱,以及Integer缓存池原理和使用场景
后端
SimonKing14 分钟前
frontend-dev vs ui-ux-pro-max:谁才是Vibe Coding前端开发的“最强辅助”?
java·后端·程序员
小谢小哥15 分钟前
57-数据同步方案详解
java·后端·架构
神奇小汤圆16 分钟前
线程池总被问住?看完这篇,彻底吃透ThreadPoolExecutor
后端
小谢小哥17 分钟前
56-最终一致性方案详解
java·后端·架构
二哈赛车手18 分钟前
新人笔记---ES和kibana启动问题以及一些常用的linux的错误排查方法
后端
用户303413198344823 分钟前
Speculative Decoding深度解析:小模型如何加速大模型推理
后端
希望永不加班26 分钟前
SpringBoot 整合 RabbitMQ 入门
java·spring boot·后端·rabbitmq·java-rabbitmq