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))

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

相关推荐
实泽有之,无泽虚之7 分钟前
ORA-12518:Oracle 监听程序无法分发客户端连接原因及解决方法
数据库·oracle
Elastic 中国社区官方博客9 分钟前
组合 OpenTelemetry 参考架构
大数据·数据库·elasticsearch·搜索引擎·架构
Z_Wonderful12 分钟前
在 **Next.js** 中使用 `mysql2` 连接 MySQL 数据库并查询 `xxx` 表的数据
android·数据库
FirstFrost --sy21 分钟前
MySql 内外连接
android·数据库·mysql
watersink29 分钟前
第16章 案例特训专题【数据库篇】
数据库
爬山算法29 分钟前
MongoDB(78)什么是MongoDB的事务?
数据库·mongodb
ego.iblacat38 分钟前
MySQL 高可用
数据库·mysql·adb
阿里小阿希43 分钟前
PostgreSQL 判断大导入是否正在执行 pg_stat_activity
数据库·postgresql
xrui581 小时前
PostgreSQL异常:An IO error occurred while sending to the backend
数据库·postgresql
卢傢蕊1 小时前
PostgreSQL 初体验
数据库·postgresql