redis批量刪除key的步驟
由于誤用插件,某臺服務(wù)器上的redis實例存在數(shù)百萬無用的key。為了刪除無用數(shù)據(jù),上網(wǎng)查找redis批量刪除key的方法,發(fā)現(xiàn)使用過程中都有問題。經(jīng)過本人的研究,終于找到redis批量刪除key的正確用法。
本文分享最新版Redis批量刪除key的方法,希望能幫到遇到同樣問題的網(wǎng)友。
redis批量刪除key
網(wǎng)上許多文章和教程給出的redis批量刪除key命令是:
redis-cli KEYS "$PATTERN" | xargs redis-cli DEL
在本人的實踐中,這條命令存在兩個問題:
1.redis-cli KEYS "$PATTERN"的結(jié)果會出現(xiàn)編號,不是純粹的key列表,如下所示:
[root@node1]# redis-cli keys "*" 1) ":default:is_blog_installed" 2) ":site-options:1-notoptions"
本人用的是Redis 5版本,未測試低版本Redis是否也會添加1),2)這樣的編號。可以想到,因為編號的存在,管道后DEL刪除的是錯誤的key;
2.如果key存在空格,管道后面的DEL將無法正確刪除。例如key是”123 4566″,傳送到管道后面刪除,就變成了刪除兩個key,與預(yù)期不符合。
經(jīng)過一番研究,redis批量刪除key的正確命令是:
redis-cli --raw KEYS "$PATTERN" | xargs -I {} redis-cli DEL "{}"
重點有兩個,分別解決上述命令存在的問題:
- 使用 –raw 參數(shù),去掉結(jié)果編號;
- xargs使用占位符,刪除key時將整個結(jié)果傳過去,避免了空格問題。
改正后的命令在本人的情況下運行正常,就是刪除兩百多萬個key有點慢,花了半個多小時。
redis批量移動key
如果你知道有用key的模式,并且有用key數(shù)量很小,可以通過redis批量移動key,然后flushdb的方法快速刪除,效率比上文提到的批量刪除大量無用key高很多。
操作方法如下:
- 批量移動key:
redis-cli --raw KEYS "$PATTERN" | xargs -L1 -I{} redis-cli MOVE {} 1
,其中命令最后的1是備份數(shù)據(jù)庫的編號; - 清空當(dāng)前數(shù)據(jù)庫:
redis-cli flushdb
; - 還原key:
redis-cli -n 1 --raw KEYS "$PATTERN" | xargs -L1 -I{} redis-cli MOVE {} 0
。
注意清空當(dāng)前數(shù)據(jù)庫的命令是 flushdb
,不能用 flushall
。flushdb
和flushall
的區(qū)別是:flushdb
只會清空當(dāng)前數(shù)據(jù)庫的數(shù)據(jù),而flushall
會清空當(dāng)前redis實例的所有數(shù)據(jù)。
redis-cli參數(shù)
上述命令使用redis-cli
工具完成,在編號為0的默認(rèn)數(shù)據(jù)庫上操作。對于需要密碼、遠(yuǎn)程redis主機(jī)的情況,redis-cli
有如下有用參數(shù):
-n:操作的數(shù)據(jù)庫;
-a:redis數(shù)據(jù)庫密碼
-h:redis主機(jī)ip,通過-h可以遠(yuǎn)程批量刪除key
-p:redis端口
更多參數(shù)請參考幫助文檔。
以上就是redis批量刪除key的步驟的詳細(xì)內(nèi)容,更多關(guān)于redis批量刪除key的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
關(guān)于Redis數(shù)據(jù)持久化的概念介紹
Redis是內(nèi)存數(shù)據(jù)庫,數(shù)據(jù)都是存儲在內(nèi)存中,需要定期將Redis中的數(shù)據(jù)以某種形式(或命數(shù)據(jù)令)從內(nèi)存保存到硬盤,今天給大家分享Redis數(shù)據(jù)的持久化的概念介紹,需要的朋友參考下吧2021-08-08詳解Redis中地理位置功能Geospatial的應(yīng)用
Geospatial?Indexes?是?Redis?提供的一種數(shù)據(jù)結(jié)構(gòu),用于存儲和查詢地理位置信息,這篇文章就來和大家詳細(xì)講講Geospatial的具體應(yīng)用吧2023-06-06redis的底層數(shù)據(jù)結(jié)構(gòu)詳解
Redis性能高得益于其優(yōu)化的數(shù)據(jù)結(jié)構(gòu),Redis的數(shù)據(jù)結(jié)構(gòu)分為對外暴露的和內(nèi)部底層的兩種,對外暴露的數(shù)據(jù)結(jié)構(gòu)包括String、list、hash、set、zset等,而內(nèi)部底層的數(shù)據(jù)結(jié)構(gòu)則包括SDS、hashtable、ziplist、linkedlist、quicklist、intset、skiplist等2025-02-02Redis常見數(shù)據(jù)類型List列表使用詳解
Redis的List是一種有序的字符串集合,支持兩端高效插入和刪除,適用于隊列和棧,這篇文章主要介紹了Redis常見數(shù)據(jù)類型List列表使用的相關(guān)資料,需要的朋友可以參考下2024-12-12