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 分钟前
Java面向对象进阶:封装、继承、多态的实现逻辑与实战案例
java·开发语言·后端·spring cloud·ar·restful
架构精进之路19 分钟前
一文搞懂什么是 Vibe Coding?
人工智能·后端
IT 行者23 分钟前
Spring Boot 4 升级指南:告别RestTemplate,拥抱现代HTTP客户端
spring boot·后端·http
qq_124987075325 分钟前
基于微信小程序的校园资讯共享平台的设计与实现(源码+论文+部署+安装)
spring boot·后端·微信小程序·小程序·毕业设计
此剑之势丶愈斩愈烈26 分钟前
Spring获取URL信息
java·后端·spring
知其然亦知其所以然1 小时前
Redis 命中率 99%,数据库却 100% CPU,是谁在捣鬼
redis·后端·面试
扎Zn了老Fe1 小时前
告别ID冲突:分布式唯一 ID 生成方案全解析
后端
天天摸鱼的java工程师1 小时前
后端密码存储优化:BCrypt 与 Argon2 加密方案对比
java·后端
我是你们的明哥1 小时前
kafka如何实现exactly once
后端
王中阳Go1 小时前
全面解析Go泛型:从1.18到最新版本的演进与实践
后端·面试·go