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
}


相关推荐
DemonAvenger6 小时前
NoSQL与MySQL混合架构设计:从入门到实战的最佳实践
数据库·mysql·性能优化
AAA修煤气灶刘哥17 小时前
别让Redis「歪脖子」!一次搞定数据倾斜与请求倾斜的捉妖记
redis·分布式·后端
AAA修煤气灶刘哥18 小时前
后端人速藏!数据库PD建模避坑指南
数据库·后端·mysql
RestCloud1 天前
揭秘 CDC 技术:让数据库同步快人一步
数据库·api
得物技术1 天前
MySQL单表为何别超2000万行?揭秘B+树与16KB页的生死博弈|得物技术
数据库·后端·mysql
christine-rr1 天前
linux常用命令(4)——压缩命令
linux·服务器·redis
可涵不会debug1 天前
【IoTDB】时序数据库选型指南:工业大数据场景下的技术突围
数据库·时序数据库
ByteBlossom1 天前
MySQL 面试场景题之如何处理 BLOB 和CLOB 数据类型?
数据库·mysql·面试
麦兜*1 天前
MongoDB Atlas 云数据库实战:从零搭建全球多节点集群
java·数据库·spring boot·mongodb·spring·spring cloud
Slaughter信仰1 天前
深入理解Java虚拟机:JVM高级特性与最佳实践(第3版)第十章知识点问答(10题)
java·jvm·数据库