zl程序教程

您现在的位置是:首页 >  其它

当前栏目

在redisCluster中模糊获取key方式

获取 方式 Key 模糊
2023-06-13 09:19:49 时间

在一个集群中,显然不能通过keys方法通过pattern直接获取key的集合;

鉴于这种问题,产生了两种思路,如下:

已知相同的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);

 ScanResult String result = jedisCluster.scan("0", scanParams);

 List String 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}*");查不出结果

获取所有的节点,分别扫描每个节点,根据pattern获取节点中的key,整合起来即可;

注意:cluster模式执行多key操作的时候,这些key必须在同一个slot上,不然会报JedisDataException异常;


@RequestMapping(value = "/ceshi3", method = RequestMethod.GET)

@ResponseBody

public void RedisKeys() {

 String redisKeyStartWith="Ad:ads:id:";

 try {

 Map String, JedisPool clusterNodes = jedisCluster.getClusterNodes();

 for (Map.Entry String, JedisPool entry : clusterNodes.entrySet()) {

 Jedis jedis = entry.getValue().getResource();

 // 判断非从节点(因为若主从复制,从节点会跟随主节点的变化而变化)

 if (!jedis.info("replication").contains("role:slave")) {

 Set String keys = jedis.keys(redisKeyStartWith + "*");

 if (keys.size() 0) {

 Map Integer, List String 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 Integer, List String 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集群密码) 如本地测试环境查询结果:

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。


我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题

本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 在redisCluster中模糊获取key方式