最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
在redisCluster中模糊获取key方式代码示例
时间:2022-06-29 10:42:45 编辑:袖梨 来源:一聚教程网
本篇文章小编给大家分享一下在redisCluster中模糊获取key方式代码示例,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。
在一个集群中,显然不能通过keys方法通过pattern直接获取key的集合;
鉴于这种问题,产生了两种思路,如下:
方案1:
已知相同的tag的KV会在一个节点上,所以只要key带有相同的hashtag,则会在一个节点上,所以只要扫描该节点即可,这样就将集群转化为了单点。
@RequestMapping(value = "/ceshi", method = RequestMethod.GET) @ResponseBody public void Rediskeys() { /** * 模糊匹配 * @param pattern key的正则表达式 * @param count 每次扫描多少条记录,值越大消耗的时间越短,但会影响redis性能。建议设为一千到一万 * @return 匹配的key集合 */ try{ jedisCluster.getClusterNodes(); ScanParams scanParams = new ScanParams(); scanParams.match("{operatingSystem}*"); scanParams.count(1000); ScanResultresult = jedisCluster.scan("0", scanParams); List keyList = result.getResult(); System.out.println("keyList======="+keyList); }finally{ } }
//scanParams.match("*{zmc}*");//success //scanParams.match("ZMC_text:{zmc}*");//success
上述match方法中:括号中的参数也可以按照如上方式编写;
其关键在于 key 上传到redis中,命名方式里面,必须含有 {};
并且{}前面、后面有无参数必须指定;若key为 ZMC_text: {zmc}:1
scanParams.match("{zmc}*");查不出结果
方案2:
获取所有的节点,分别扫描每个节点,根据pattern获取节点中的key,整合起来即可;
注意:cluster模式执行多key操作的时候,这些key必须在同一个slot上,不然会报JedisDataException异常;
@RequestMapping(value = "/ceshi3", method = RequestMethod.GET) @ResponseBody public void RedisKeys() { String redisKeyStartWith="Ad:ads:id:"; try { MapclusterNodes = jedisCluster.getClusterNodes(); for (Map.Entry entry : clusterNodes.entrySet()) { Jedis jedis = entry.getValue().getResource(); // 判断非从节点(因为若主从复制,从节点会跟随主节点的变化而变化) if (!jedis.info("replication").contains("role:slave")) { Set keys = jedis.keys(redisKeyStartWith + "*"); if (keys.size() > 0) { Map > map = new HashMap<>(); for (String key : keys) { // cluster模式执行多key操作的时候,这些key必须在同一个slot上,不然会报:JedisDataException: // CROSSSLOT Keys in request don't hash to the same slot int slot = JedisClusterCRC16.getSlot(key); // 按slot将key分组,相同slot的key一起提交 if (map.containsKey(slot)) { map.get(slot).add(key); } else { map.put(slot, Lists.newArrayList(key)); } } for (Map.Entry > integerListEntry : map.entrySet()) { System.out.println("integerListEntry="+integerListEntry); //jedis.del(integerListEntry.getValue().toArray(new String[integerListEntry.getValue().size()])); } } } } logger.info("success redisKeys:{}", redisKeyStartWith); } finally { } }
redis集群获取所有的key
redis单机查询所有key命令
keys *
查询结果示例:
redis集群查所有key命令:
如果使用keys *,那么查询的仍旧是本服务器的所有key,不是集群的(结合本图结果以及参考上图,都是插入后查询,无心插入或者删除key)
正确的命令是
./redis-cli -c --cluster call 192.168.168.161:7001 keys *
注意:
1.不能去掉;
2.换成你redis集群的一个节点的ip和端口
3.如果集群有密码加上参数 -a password(你的redis集群密码) 如本地测试环境查询结果:
相关文章
- 人们熟悉的寄居蟹属于以下哪种分类 神奇海洋11月21日答案 11-21
- 第五人格11.22共研服有什么更新 11月22日共研服更新内容介绍 11-21
- 原神恰斯卡怎么培养 11-21
- 无期迷途四星装束是谁 11-21
- 王者荣耀帝丹高中校服怎么获得 11-21
- 光遇姆明季后续版本怎么玩 11-21