Redis模糊匹配删除key

时间:2022-11-10 19:05:45

在群里看到的一个Redis 快速删除数据 小技巧。之前我一直用scan出来再删方式,比较慢,不如本文下面这个方法。


造些测试数据

for i in {1..1000};do echo "set age_$i $i" | redis-cli -c -p 7000 ;done


单机 查找数据(每行显示10条记录)

redis-cli -c -p 7000 --scan --pattern "age_*" | xargs -L 10

单机 删除

redis-cli --scan --pattern "age_*" | xargs -L 10 redis-cli -n 0 unlink

对于redis cluster的稍微费事点

cluster 查找数据

redis-cli -c -p 7000 --scan --pattern "age_*" | xargs -L 1

说明:这里-L 1 让它每行只显示一条记录。因为显示多条记录的话,key可能不在一个slot里面,后续做批量删除会报错的,索性每次一条罢了!


cluster 删除数据

redis-cli -c -p 7000 --scan --pattern "age_*" | xargs -L 1 redis-cli -c -p 7000 -n 0 unlink


遍历redis cluster各分片删除

for port in {7000..7005}; do
redis-cli -c -p ${port} -h 192.168.31.181 --scan --pattern "age_*" | xargs -L 1 redis-cli -h 192.168.31.181 -c -p ${port} -n 0 unlink
done