Redis——使用lua脚本模糊删除数据

前言

多多点赞,会变好看!

多多留言,会变有钱!

本文适用于Redis集群,是否适用单机模式未做测试!

一、创建lua脚本:

命名为clear_data.lua

Lua 复制代码
redis.call("select",0)

--游标的id
local cursor = 0
--查找删除的key的数量
local keyNum = 0
repeat
  --使用scan搜索,cursor=0的时候标识一个新的迭代期,服务器返回0的时候表示迭代已经结束
  local res = redis.call("scan",cursor,"MATCH",KEYS[1])
  if(res ~= nil and #res>=0) then
    cursor = tonumber(res[1])
    local ks = res[2]
    if(ks ~= nil and #ks>0) then
      redis.replicate_commands()
      --循环删除当前迭代器迭代出的数据
      for i=1,#ks,1 do
        local key = tostring(ks[i])
        --使用UNLINK删除,区别于del的是这个是异步执行的
        --这条指令要版本大于4.0.0 小于4.0.0就使用del
        redis.call("UNLINK",key)
      end
      --统计删除的key的数量
      keyNum = keyNum + #ks
    end
  end
--当服务器返回0的时候,跳出循环
until( cursor <= 0 )

return keyNum

二、执行命令

命令:/Redis路径/redis-cli -c -h IP -p 端口 --eval /脚本路径/clear_data.lua "模糊匹配值"

案例:/usr/local/redis/bin/redis-cli -c -h 127.0.0.1 -p 6379 --eval /root/clear_data.lua "*test??:*"

模糊匹配值一定要写正确,不然删错可就麻烦了!!

相关推荐
vegetablec17 小时前
CSS如何制作卡片翻开呈现另一面的翻牌动画
jvm·数据库·python
身如柳絮随风扬17 小时前
Redis 单线程模型
redis
吕源林17 小时前
Golang怎么Redis发布订阅_Golang如何用Publish和Subscribe收发消息【实战】
jvm·数据库·python
redreamSo17 小时前
Turso:用 Rust 重写 SQLite,让数据库跑在每一个边缘节点
数据库·rust·sqlite
2301_7641505617 小时前
Golang colly爬虫框架如何用_Golang colly教程【进阶】
jvm·数据库·python
2301_8035389518 小时前
SQL统计各分组中排名前三的记录_使用窗口函数RANK
jvm·数据库·python
2301_7826591818 小时前
如何让按钮悬停时阴影位置保持固定(仅按钮位移)
jvm·数据库·python
weixin_5806140018 小时前
如何用 performance.navigation 判断页面刷新并清理缓存
jvm·数据库·python
214396518 小时前
Golang strings.Builder如何用_Golang Builder拼接教程【对比】
jvm·数据库·python
2301_7775993718 小时前
mysql如何配置主机缓存_mysql host_cache_size设置
jvm·数据库·python