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);
}
相关推荐
Dinwork4 小时前
Skills 开发指南-结合示例详细讲解skills原理和使用方法
后端
生锈的键盘4 小时前
rk3588目标检测:Jupyter中OpenCV实时预览方法
后端
舒一笑4 小时前
Windows 使用 Codex / AI 编程时 IDEA 中文乱码?一篇文章彻底解决
后端·程序员·intellij idea
兆子龙4 小时前
Linux 网络栈与 epoll:从网卡到用户态的高性能 I/O 模型剖析
后端·架构
若水不如远方4 小时前
分布式一致性协议(五):殊途同归 —— ZAB 协议与 ZooKeeper 架构
分布式·后端·zookeeper
我叫黑大帅4 小时前
如何使用WebSocket实现一个公域聊天室? --Go
后端·面试·go
只做人间不老仙4 小时前
C++ grpc rpc取消示例学习
后端·grpc
小码哥_常4 小时前
别再被忽悠!finally代码真的一定执行?
后端
来了老板4 小时前
Spring Boot 项目优雅上线:日志、监控、异常处理最佳实践
后端
Java编程爱好者4 小时前
如何将 Spring Statemachine 作为一个轻量级工作流引擎来使用?
后端