Redis批量删除Key的三种方式

Redis批量删除Key的三种高效方法

方法一:使用通配符匹配删除

通过KEYS命令配合通配符筛选键值,再传递给DEL命令批量删除:

bash 复制代码
redis-cli KEYS "user:*" | xargs redis-cli DEL

注意 :当键数量超过10^4时,建议分批处理。使用SCAN替代KEYS可避免阻塞:

bash 复制代码
redis-cli --scan --pattern "cache:*" | xargs -L 1000 redis-cli DEL
方法二:Lua脚本原子操作

通过执行Lua脚本实现原子化批量删除(Redis 2.6+支持):

lua 复制代码
local keys = redis.call('KEYS', ARGV[1])
for i=1,#keys,5000 do
    redis.call('DEL', unpack(keys, i, math.min(i+4999, #keys)))
end
return #keys

执行命令:

bash 复制代码
redis-cli EVAL "$(cat delkeys.lua)" 0 "order_*"
方法三:管道批量处理

利用redis-cli管道特性实现高效删除:

bash 复制代码
redis-cli --scan --pattern "temp_*" | \
awk '{print "DEL "$0}' | \
redis-cli --pipe

方案对比与选型建议

方式 适用场景 风险控制 性能影响
KEYS+DEL 测试环境、小数据量
SCAN+DEL 生产环境、大数据量
Lua脚本 需要原子性、复杂逻辑

注意事项:

  1. 所有删除操作不可逆,建议先备份数据
  2. 复杂匹配模式建议用SCAN替代KEYS
  3. 超大数据量可拆分多次执行,避免内存溢出
相关推荐
秋921 小时前
MySQL 9.7.0 使用详解:新特性、实战与避坑指南
android·数据库·mysql
S1998_1997111609•X21 小时前
恶意注入污染蜜罐HDMI进程函数值进行封禁垃圾蠕虫仓蟲的轮系依据行为戆直㞢仓shell token
数据库·爬虫·网络协议·百度·开闭原则
Komore3151 天前
商户查询缓存
java·redis·缓存
Yupureki1 天前
《Redis数据库》1.初识Redis
数据库·redis·缓存
Lyyaoo.1 天前
Redis实现分布式锁
数据库·redis·分布式
张~颜1 天前
autovacuum
数据库·postgresql
山峰哥1 天前
SQL优化从入门到精通:20个案例破解性能密码
数据库·sql·oracle·性能优化·深度优先
努力努力再努力wz1 天前
【MySQL进阶系列】拒绝冗余SQL:带你透彻理解视图的底层逻辑
android·c语言·数据结构·数据库·c++·sql·mysql
历程里程碑1 天前
MySQL数据类型全解析 + 代码实操讲解
大数据·开发语言·数据库·sql·mysql·elasticsearch·搜索引擎
杨云龙UP1 天前
Windows Server 2012 环境下 Oracle 11.2 使用 expdp 实现自动备份、异地复制与定期清理_20260504
服务器·数据库·windows·mysql·docker·oracle·容器