redis如何批量删除key
2023-12-27 18:31:37
在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
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))
执行完毕后等待删除完毕即可。
文章来源:https://blog.csdn.net/qq_42476938/article/details/135252035
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!