国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫 - Redis - Redis Cluster 字段模糊匹配及刪除

Redis Cluster 字段模糊匹配及刪除

2021-08-06 17:51在風(fēng)中的意志 Redis

在數(shù)據(jù)庫內(nèi)我們可以通過like關(guān)鍵字、%、*或者REGEX關(guān)鍵字進(jìn)行模糊匹配。而在Redis內(nèi)我們?nèi)绾芜M(jìn)行模糊匹配呢?本文就來介紹一下

Questions

在數(shù)據(jù)庫內(nèi)我們可以通過like關(guān)鍵字、%、*或者REGEX關(guān)鍵字進(jìn)行模糊匹配。而在Redis內(nèi)我們?nèi)绾芜M(jìn)行模糊匹配呢?集群情況Redis Cluster的情況是否和單機(jī)一致呢?前段時(shí)間我對(duì)于這個(gè)議題進(jìn)行了調(diào)查和研究。

單節(jié)點(diǎn)的情況

Jedis
參考stackoverflow上的解答,在Java內(nèi)使用Jedis主要有如下2中寫法:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
### 方法1
Set<String> keys = jedis.keys(pattern);
for (String key : keys) {
    jedis.del(key);
}
 
### 方法2
Jedis jedis = new Jedis("127.0.0.1");
ScanParams scanParams = new ScanParams();
scanParams.match("prifix*");
scanParams.count(1000);
ScanResult<String> result = jedis.scan(0,scanParams);
result.getResult().forEach(key -> {
    jedis.del(key);
});
 
### 注意scan方法由于某些bug在2.9版本內(nèi)scan(int,ScanParams)改為了scan(String,ScanParams)。由于cursor的位數(shù),方法有些調(diào)整。

方法1,通過keys命令先尋找到所有符合的key,然后把它們刪除
方法2,通過scan命令掃描所有符合的key,然后把它們刪除。
注意: Redis飾單線程模式,全局掃描的話有可能會(huì)導(dǎo)致Redis在一段時(shí)間內(nèi)的卡頓情況發(fā)生。

Redis-cli

?
1
redis-cli keys 1.cn*|xargs redis-cli del

Redis Cluster情況

在Redis Cluster情況與單節(jié)點(diǎn)多情況完全不太一樣。

  • 首先,Redis Cluster是將整個(gè)Redis 的hash槽分布在三臺(tái)機(jī)器上,要想一下全部掃描出來,顯然是不太現(xiàn)實(shí)的。
  • Redis內(nèi)提供Hash-Tag,將相類似的鍵放在一臺(tái)機(jī)器上。可以通過Hash-Tag進(jìn)行掃描,可以剪短時(shí)間消耗。
  • 最后需要考慮,主從集群節(jié)點(diǎn)的情況。

Hash-Tag

Hash-Tag 是用一個(gè)花括號(hào)將主要的Hash判斷部分?jǐn)U起來,例如{hello1}key1、{hello1}key2。一般Hash-tag一致的情況,鍵會(huì)存儲(chǔ)在集群的同一臺(tái)機(jī)器上。在Jedis 2.9版本提供了這樣的掃描方法。
(PS . rediscluster是沒有keys方法的)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
public static void deleteRedisKeyStartWith(String redisKeyStartWith) {
        try{
            jedisCluster.getClusterNodes();
 
            ScanParams scanParams = new ScanParams();
//          scanParams.match("{123}keys*");
 
//          scanParams.count(1000);
            ScanResult<String> result = jedisCluster.scan("0", scanParams);
            result.getResult().forEach(key -> {
                jedisCluster.del(key);
            });
//          jedisCluster.del(wrapperKey(redisKeyStartWith)+".*");
            log.info("success deleted redisKeyStartWith:{}", redisKeyStartWith);
        }finally{
        }
    }

土辦法 分別掃描各個(gè)hash槽

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
public static void deleteRedisKeyStartWith(String redisKeyStartWith) {
        try {
            Map<String, JedisPool> clusterNodes = jedisCluster.getClusterNodes();
 
            for (Map.Entry<String, JedisPool> entry : clusterNodes.entrySet()) {
                Jedis jedis = entry.getValue().getResource();
                // 判斷非從節(jié)點(diǎn)(因?yàn)槿糁鲝膹?fù)制,從節(jié)點(diǎn)會(huì)跟隨主節(jié)點(diǎn)的變化而變化)
                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模式執(zhí)行多key操作的時(shí)候,這些key必須在同一個(gè)slot上,不然會(huì)報(bào):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()) {
                            jedis.del(integerListEntry.getValue().toArray(new String[integerListEntry.getValue().size()]));
                        }
                    }
                }
            }
            log.info("success deleted redisKeyStartWith:{}", redisKeyStartWith);
        } finally {
        }
    }
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
### 未使用slot批次提交(有可能效率略差于前者)
//獲取jedis連接
 
         private JedisCluster jedisCluster=JedisClusterUtil.getJedisCluster();
 
         //@param pattern  獲取key的前綴  全是是 *
 
 public static TreeSet<String> keys(String pattern){ 
 
 
       TreeSet<String> keys = new TreeSet<>(); 
        //獲取所有的節(jié)點(diǎn)
 
               Map<String, JedisPool> clusterNodes = jedisCluster.getClusterNodes(); 
       //遍歷節(jié)點(diǎn) 獲取所有符合條件的KEY
 
               for(String k : clusterNodes.keySet()){ 
           logger.debug("Getting keys from: {}", k); 
           JedisPool jp = clusterNodes.get(k); 
           Jedis connection = jp.getResource(); 
           try
               keys.addAll(connection.keys(pattern)); 
           } catch(Exception e){ 
               logger.error("Getting keys error: {}", e); 
           } finally
               logger.debug("Connection closed."); 
               connection.close();//用完一定要close這個(gè)鏈接!!! 
           
       
       logger.debug("Keys gotten!"); 
       return keys; 
  
 
          //main方法
 
 public static void main(String[] args ){
 TreeSet<String> keys=keys("*");
 
 //遍歷key  進(jìn)行刪除  可以用多線程
 
 for(String key:keys){
 
                          jedisCluster.del(key);
 System.out.println(key);
 }
 }

Reference

[1]. (碼經(jīng))如何通過正則匹配刪除Redis里的鍵
[2]. (Stackoverflow)Redis/Jedis - Delete by pattern?
[3]. (JavaDoc)Class JedisCluster
[4]. (csdn)redis cluster 模式如何批量刪除指定前綴的key
[5]. redis cluster模式key的模糊刪除-java操作
[6]. Jedis實(shí)現(xiàn)批量刪除redis cluster
[6]. redis del命令支持正則刪除(pattern)
[7]. Redis 批量刪除Redis的key 正則匹配刪除
[8]. (名字挺搞笑-蛋糕店老板)Redis集群下使用Jedis實(shí)現(xiàn)keys模糊查詢

到此這篇關(guān)于Redis Cluster 字段模糊匹配及刪除的文章就介紹到這了,更多相關(guān)Redis Cluster 字段模糊刪除內(nèi)容請(qǐng)搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!

原文鏈接:https://yanxml.blog.csdn.net/article/details/80754171

延伸 · 閱讀

精彩推薦
  • Redisredis中如何使用lua腳本讓你的靈活性提高5個(gè)逼格詳解

    redis中如何使用lua腳本讓你的靈活性提高5個(gè)逼格詳解

    這篇文章主要給大家介紹了關(guān)于redis中如何使用lua腳本讓你的靈活性提高5個(gè)逼格的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具...

    一線碼農(nóng)5812019-11-18
  • Redisredis實(shí)現(xiàn)排行榜功能

    redis實(shí)現(xiàn)排行榜功能

    排行榜在很多地方都能使用到,redis的zset可以很方便地用來實(shí)現(xiàn)排行榜功能,本文就來簡(jiǎn)單的介紹一下如何使用,具有一定的參考價(jià)值,感興趣的小伙伴們...

    乘月歸5022021-08-05
  • Redis詳解Redis復(fù)制原理

    詳解Redis復(fù)制原理

    與大多數(shù)db一樣,Redis也提供了復(fù)制機(jī)制,以滿足故障恢復(fù)和負(fù)載均衡等需求。復(fù)制也是Redis高可用的基礎(chǔ),哨兵和集群都是建立在復(fù)制基礎(chǔ)上實(shí)現(xiàn)高可用的...

    李留廣10222021-08-09
  • RedisRedis如何實(shí)現(xiàn)數(shù)據(jù)庫讀寫分離詳解

    Redis如何實(shí)現(xiàn)數(shù)據(jù)庫讀寫分離詳解

    Redis的主從架構(gòu),能幫助我們實(shí)現(xiàn)讀多,寫少的情況,下面這篇文章主要給大家介紹了關(guān)于Redis如何實(shí)現(xiàn)數(shù)據(jù)庫讀寫分離的相關(guān)資料,文中通過示例代碼介紹...

    羅兵漂流記6092019-11-11
  • RedisRedis 事務(wù)知識(shí)點(diǎn)相關(guān)總結(jié)

    Redis 事務(wù)知識(shí)點(diǎn)相關(guān)總結(jié)

    這篇文章主要介紹了Redis 事務(wù)相關(guān)總結(jié),幫助大家更好的理解和學(xué)習(xí)使用Redis,感興趣的朋友可以了解下...

    AsiaYe8232021-07-28
  • RedisRedis全量復(fù)制與部分復(fù)制示例詳解

    Redis全量復(fù)制與部分復(fù)制示例詳解

    這篇文章主要給大家介紹了關(guān)于Redis全量復(fù)制與部分復(fù)制的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Redis爬蟲具有一定的參考學(xué)習(xí)...

    豆子先生5052019-11-27
  • RedisRedis的配置、啟動(dòng)、操作和關(guān)閉方法

    Redis的配置、啟動(dòng)、操作和關(guān)閉方法

    今天小編就為大家分享一篇Redis的配置、啟動(dòng)、操作和關(guān)閉方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧 ...

    大道化簡(jiǎn)5312019-11-14
  • Redisredis 交集、并集、差集的具體使用

    redis 交集、并集、差集的具體使用

    這篇文章主要介紹了redis 交集、并集、差集的具體使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友...

    xiaojin21cen10152021-07-27
主站蜘蛛池模板: 欧美电影一区 | 国产在线不卡 | 91看视频 | 日本欧美在线观看 | 精品亚洲永久免费精品 | 永久黄网站色视频免费观看w | 国产一区二区三区在线免费观看 | 在线免费观看黄色 | 亚洲综合色视频在线观看 | 色成人免费网站 | 国产一区二区三区免费播放 | 成人在线观看网站 | 国产成人亚洲精品 | 精品久久久久久久人人人人传媒 | 一区二区视频在线 | 亚洲品质自拍视频网站 | 精品女同一区二区三区在线绯色 | 亚洲91av| 亚洲精品成a人在线 | 欧美片网站免费 | 成人免费视频网 | 亚洲 欧美 日韩在线 | 中文字幕一区在线观看视频 | 九色av| 在线观看91免费视频 | 日韩精品一区二区三区免费视频 | 91精品区 | 久久精品国产免费 | 自拍偷拍第一页 | 中文字幕三区 | 欧美日韩一二区 | 91视频导航| 国产97色在线 | 亚洲 | 中文字幕二区 | 亚洲精品一 | 国产乱码精品一区二区三 | 亚洲精品国产精品国自产在线 | 91原创国产 | 欧美午夜影院 | 亚洲高清视频在线 | 一级在线 |