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);
}
相关推荐
屋外雨大,惊蛰出没1 分钟前
spring boot+mybatis开发基础复习
java·spring boot·后端
叫我少年5 分钟前
C# 文件级 using(global using)
后端
郝学胜_神的一滴6 分钟前
系统设计 014:缓存深度实战:如何用 Cache 优雅优化数据库读写?
前端·后端·面试
ai程序羊沸沸8 分钟前
Spring Cloud 微服务入门:从组件清单到问题驱动的学习路径
后端·微服务
铁皮饭盒16 分钟前
sharp.js安装不上, Bun.Image说: 我不用安装
前端·后端
无风听海16 分钟前
ASP.NET Core 中的重定向(Redirect)深度解析
后端·asp.net
掘金者阿豪17 分钟前
Node.js 连金仓数据库(下篇):连接池、事务和那些坑
后端
郑州光合科技余经理31 分钟前
海外版外卖系统源码:支付/地图/多语言核心代码实现
android·java·前端·后端·架构·uni-app·php
jeffer_liu36 分钟前
Spring AI 生产级实战:多模态
java·人工智能·后端·spring·大模型
Gopher_HBo41 分钟前
Go语言学习笔记(五)异常处理
后端