集群模式下RedisTemplate使用Scan命令全节点模糊匹配key

为什么需要模糊匹配key?

因为有时候,缓存的key设计的不合理,比如商品信息的缓存设计成:门店编码+商品id,

当我们需要查询一个门店下的所有商品缓存的时候,可能就需要获取这个门店编码下的所有商品信

息的key然后遍历获取门店下的所有商品。

为什么使用Scan?

因为Keys是阻塞的,严重影响性能,官方不建议生产环境使用,取而代之的是Scan命令。

Scan命令怎么使用呢?

语法: scan cursor [MATCH pattern] [COUNT count]

语法说明:[]里面的代表可选可不选

scan :命令关键字

cursor :起始下标

MATCH pattern:MATCH是关键字全大写, pattern是要模糊匹配的正则表达式 默认是*

COUNT count:COUNT是关键字全大写,count是模糊匹配的数量 默认是10

比如 :

  • scan 0 :从0下标开始全匹配
  • scan 0 MATCH ab* :从0下标开始10个key,匹配其中找到ab开头的key
  • scan 0 MATCH ab* COUNT 100 :从0下标开始100个key,匹配其中找到ab开头的key

Redis支持的正则表达式:

? :代表任意字符

* :代表任意长度的字符

[] :代表[]中的任意一个字符,[abc]表示abc中的任意一个字符

比如我想模糊匹配下面的key:

1) "md:v2:pd:preSell:storeCodeAndSkuId[storeCode,skuId]:[0008,63168]"
2) "md:v2:pd:preSell:storeCodeAndSkuId[storeCode,skuId]:[0008,12685]"
3) "md:v2:pd:preSell:storeCodeAndSkuId[storeCode,skuId]:[0008,4632809]"
4) "md:v2:pd:preSell:storeCodeAndSkuId[storeCode,skuId]:[0008,4693253]"

命令如下

scan 0 MATCH md:v2:pd:preSell:storeCodeAndSkuId?storeCode,skuId?:?0008,*? COUNT 100000

scan 命令返回的是个数组,数组的第一个值是scan到的cursor位置,第二个值就是匹配的key的数组,第一个值每次返回的值可能看起来有点奇怪,建议参考深入理解Redis的scan命令

Scan命令的限制?

scan命令只能在一个Redis节点上遍历,如果是集群的话,他并不能遍历所有Redis节点

怎么用Scan命令遍历通过RedisTemplate遍历所有Redis集群里的节点呢?

    public static Set<String> scanMatch(String matchKey) {
        Set<String> keys = new HashSet();
        RedisConnectionFactory connectionFactory = redisTemplate.getConnectionFactory();
        RedisClusterConnection clusterConnection = connectionFactory.getClusterConnection();
        Iterable<RedisClusterNode> redisClusterNodes = clusterConnection.clusterGetNodes();
        Iterator<RedisClusterNode> iterator = redisClusterNodes.iterator();
        while (iterator.hasNext()) {
            RedisClusterNode next = iterator.next();
            Cursor<byte[]> scan = clusterConnection.scan(next, ScanOptions.scanOptions().match(matchKey).count(10000000).build());
            while (scan.hasNext()) {
                keys.add(new String(scan.next()));
            }
        }
        return keys;
    }

  • 3
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值