redis目前还不支持批量删除key的命令,但是我们有时需要删除符合某个规则的keys,
keys+xargs实现
有两种方式:
1.使用redis-cli keys “clown*”获取到以clown开始的键,然后使用redis-cli del删除这些键—-过于繁琐,不推荐使用
2.使用redis-cli keys “clown*” |xargs redis-cli del一次删除,及其方便而且不会遗漏
./redis-cli -h 127.0.0.1 -p 6379 keys "clown*" | xargs ./redis-cli -h 127.0.0.1 -p 6379 del
注意事项:
redis是单线程架构,如果redis包含了大量的键,执行keys命令可能会造成redis阻塞,所以一般建议不要在生产环境下使用keys命令。如果非要遍历键删除的话,可以在以下三种情况使用:
(1).在一个不对外提供服务的Redis从节点上执行,这样不会阻塞到客户端的请求,但是会影响到主从复制。
(2).如果确认键值总数确实比较少,可以执行该命令。
(3).使用scan命令渐进式的遍历所有键,可以有效防止阻塞。
scan+xargs实现
批量删除
./redis-cli -h 127.0.0.1 -p 6379 --scan --pattern 'clown*' | xargs ./redis-cli -h 127.0.0.1 -p 6379 del
xargs命令介绍
xargs 可以将管道或标准输入(stdin)数据转换成命令行参数,也能够从文件的输出中读取数据。
xargs 是一个强有力的命令,它能够捕获一个命令的输出,然后传递给另外一个命令。
./redis-cli -h 127.0.0.1 -p 6379 keys "clown*" | xargs ./redis-cli -h 127.0.0.1 -p 6379 del
上述命令解释:
就是用keys clown*查询出所有匹配的key,通过xargs命令,将前面查询出来的key作为后面redis的del命令的输入,这样就可以实现redis批量删除键了。