在群里看到的一个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