redis如何批量删除key

在redis-cli或者rdm可视化工具中删除

执行命令行:DEL keyword1:keyword2:Id:7316*

表示删除形如 keyword1:keyword2:Id:7316123222,keyword1:keyword2:Id:7316123223的key,在redis中存储的key一般是前面都相同的,后面为变量

lua脚本删除

如果数据量巨大时,比如几百万key或者十几个G左右的数据,执行del会导致redis卡死和效率过低

此时通过lua脚本可以高效的批量删除key

本文通过python示例,执行lua脚本批量删除key

python 复制代码
import redis
import time
# 连接到 Redis
r = redis.Redis(host='localhost', port=3306, password="password",db=0)

# 定义 Lua 脚本
lua_script = """
local keys = redis.call('KEYS', 'keyword1:keyword2:Id:7316*')
for _, key in ipairs(keys) do
    redis.call('DEL', key)
end
return #keys
"""
start = time.time()

# 执行 Lua 脚本
result = r.eval(lua_script, 0)
end = time.time()
time_range = float(end-start)
print(f"Deleted {result} keys.")
print("耗时{} s".format(time_range))

执行完毕后等待删除完毕即可。

相关推荐
IT摆渡者1 小时前
MySQL性能巡检脚本分析报告
数据库·mysql
Lyyaoo.2 小时前
Redis基础
数据库·redis·缓存
杨云龙UP2 小时前
ODA登录ODA Web管理界面时提示Password Expired的处理方法_20260423
linux·运维·服务器·数据库·oracle
解救女汉子3 小时前
SQL触发器如何获取触发源应用名_利用APP_NAME函数追踪
jvm·数据库·python
yuweiade3 小时前
Spring Boot 整合 Redis 步骤详解
spring boot·redis·bootstrap
weixin_520649874 小时前
数据库函数
数据库
Bert.Cai5 小时前
MySQL LPAD()函数详解
数据库·mysql
JH30736 小时前
RedLock-红锁
java·redis
一嘴一个橘子6 小时前
redis 启动
redis
OnlyEasyCode6 小时前
Navicat 任务自动备份指定数据库
数据库