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. 超大数据量可拆分多次执行,避免内存溢出
相关推荐
会敲键盘的猕猴桃很大胆9 分钟前
Redis实战-缓存篇(万字总结)
java·数据库·spring boot·redis·缓存
敲键盘的小夜猫29 分钟前
Milvus分区-分片-段结构详解与最佳实践
java·数据库·milvus
結城1 小时前
sharding jdbc的使用,如何在Spring中实现数据库的主从分离、分库分表等功能
java·数据库·spring
椰椰椰耶1 小时前
[网页五子棋][用户模块]数据库设计和配置(MyBatis)、约定前后端交互接口、服务器开发
数据库·mybatis·交互
Allen_LVyingbo1 小时前
大型三甲医院更换HIS系统全流程分析与经验考察(下)
数据库·健康医疗
猫咪-95271 小时前
Mysql之用户管理
数据库·mysql·oracle
岁忧4 小时前
LeetCode 高频 SQL 50 题(基础版)之 【连接】部分 · 上
数据库·sql·leetcode
DBWYX7 小时前
MongoDB
数据库·mongodb
xq5148637 小时前
MongoDB基础知识(浅显)
数据库·mongodb
观测云7 小时前
MySQL 可观测性最佳实践
数据库·mysql