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

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

相关推荐
indexsunny20 小时前
互联网大厂Java求职面试实战:Spring Boot微服务与Redis缓存场景解析
java·spring boot·redis·缓存·微服务·消息队列·电商
DBA小马哥20 小时前
时序数据库迁移替换与时序数据库分片
数据库·时序数据库
DBA小马哥20 小时前
时序数据库迁移方案在物联网设备监测中的实践与性能突破
数据库·物联网·时序数据库
ID_1800790547320 小时前
小红书笔记详情API接口基础解析:数据结构与调用方式
数据结构·数据库·笔记
起名时在学Aiifox1 天前
Vue 3 响应式缓存策略:从页面状态追踪到智能数据管理
前端·vue.js·缓存
ruleslol1 天前
MySQL的段、区、页、行 详解
数据库·mysql
while(1){yan}1 天前
MyBatis Generator
数据库·spring boot·java-ee·mybatis
それども1 天前
MySQL affectedRows 计算逻辑
数据库·mysql
是小章啊1 天前
MySQL 之SQL 执行规则及索引详解
数据库·sql·mysql
富士康质检员张全蛋1 天前
JDBC 连接池
数据库