redis中根据通配符删除key

redis中根据通配符删除key

  1. 我们是不是在redis中keys user:*可以获取所有key,但是 del user:*却不行
  2. 这里我提供的命令主要是SCAN
  3. SCAN 0 MATCH user:* COUNT 100
  4. 使用lua保证原子性

SCAN参数描述

  • 在示例中,COUNT 被设置为 100。这是一个防止一次性获取大量数据而导致性能问题的一种策略。
  • 如果你的键数量可能很大,你可以根据实际情况适当调整 COUNT 的值。如果你希望一次性获取所有匹配的键,可以将 COUNT 设置为一个足够大的值,或者不指定 COUNT 参数,让 Redis 返回所有匹配的键。
  • COUNT 参数并不是用来限制返回结果的数量的,是控制每次迭代返回的元素数量
  • 请注意,使用较大的 COUNT 值可能会导致 SCAN 命令返回的响应时间增加,具体的选择需要根据你的实际场景和性能需求来调整。

SCAN返回参数

  • 第一个元素是一个整数,表示下一次调用 SCAN 命令时应该使用的新游标 。如果游标为 0,则表示遍历完成。
  • 第二个元素是一个数组,包含了匹配模式的键。这个数组的长度可以小于等于 COUNT 参数指定的数量。

这是我的lua脚本

lua 复制代码
-- Lua脚本:根据通配符删除键
-- KEYS[1]: 匹配的键的通配符
local keyPattern = KEYS[1]

local cursor = 0
local keys = {}

repeat
    local result = redis.call("SCAN", cursor, "MATCH", keyPattern, "COUNT", 100)
    cursor = tonumber(result[1])
    local replyKeys = result[2]
    for _, key in ipairs(replyKeys) do
        table.insert(keys, key)
    end
until cursor == 0

-- 逐个删除键
for _, key in ipairs(keys) do
    redis.call("DEL", key)
end

使用golang实现

go 复制代码
// 根据通配符删除
// 使用lua保证原子性
func DeleteRedisKeysByPattern(conn redis.Conn, key string) error {
	// 读取Lua脚本内容
	luaScript := `
		local cursor = 0
		local keys = {}

		repeat
		    local result = redis.call("SCAN", cursor, "MATCH", ARGV[1], "COUNT", 100)
		    cursor = tonumber(result[1])
		    local replyKeys = result[2]
		    for _, key in ipairs(replyKeys) do
		        table.insert(keys, key)
		    end
		until cursor == 0

		-- 逐个删除键
		for _, key in ipairs(keys) do
		    redis.call("DEL", key)
		end
	`

	// 将Lua脚本注册到Redis连接
	script := redis.NewScript(0, luaScript)

	// 执行Lua脚本
	_, err := script.Do(conn, key)
	if err != nil {
		fmt.Println("Lua脚本执行失败:", err)
		return err
	}
	return nil
}


相关推荐
一叶飘零_sweeeet1 小时前
从手写 Redis 分布式锁到精通 Redisson:分布式系统的并发控制终极指南
redis·分布式·redisson
睡觉的时候不会困1 小时前
Redis 主从复制详解:原理、配置与主从切换实战
数据库·redis·bootstrap
程序员的世界你不懂3 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
自学也学好编程3 小时前
【数据库】Redis详解:内存数据库与缓存之王
数据库·redis
JAVA不会写4 小时前
在Mybatis plus中如何使用自定义Sql
数据库·sql
IT 小阿姨(数据库)4 小时前
PgSQL监控死元组和自动清理状态的SQL语句执行报错ERROR: division by zero原因分析和解决方法
linux·运维·数据库·sql·postgresql·centos
ChinaRainbowSea4 小时前
7. LangChain4j + 记忆缓存详细说明
java·数据库·redis·后端·缓存·langchain·ai编程
小马学嵌入式~5 小时前
嵌入式 SQLite 数据库开发笔记
linux·c语言·数据库·笔记·sql·学习·sqlite
Java小白程序员6 小时前
MyBatis基础到高级实践:全方位指南(中)
数据库·mybatis
Monly216 小时前
人大金仓:merge sql error, dbType null, druid-1.2.20
数据库·sql