服务器批量清理redis keys,无法适用客户端必须直连的情况

在 Redis 中,批量清理指定模式的键(例如 memberCardData:*)可以通过多种方法来实现。需要注意的是,Redis 的命令执行是单线程的,因此对大量键进行操作时可能会阻塞服务器。以下是几种常见的方法:

shell

复制代码
KEYS memberCardData:*

使用 KEYS 命令(不推荐用于生产环境)

然后你可以使用 DEL 命令删除这些键。但是,KEYS 命令会遍历整个键空间,这在大数据集上是非常慢且消耗资源的操作,可能会导致 Redis 服务短时间不可用,因此不建议在生产环境中使用。

使用 SCAN 命令

SCAN 是一个增量迭代器,它提供了非阻塞地迭代数据库键的能力。你可以结合 SCAN 和 DEL 来安全地删除匹配的键。这里是一个简单的例子,展示如何使用 SCAN 来查找并删除键:

复制代码
SCAN 0 MATCH memberCardData:* COUNT 100

这个命令将返回最多 100 个匹配的键,你可以接着用 DEL 命令删除它们。为了确保所有匹配的键都被删除,你需要在一个循环中不断调用 SCAN,直到游标返回 0。

bash 的运行命令如下:

bash 复制代码
redis-cli -h <host> -p <port> -a <password> --scan --pattern 'memberCardData:*' | xargs redis-cli -h <host> -p <port> -a <password> del

lua

lua 复制代码
local keys = redis.call('KEYS', 'memberCardData:*')
if next(keys) ~= nil then
    redis.call('DEL', unpack(keys))
end
return #keys

你可以通过 EVAL 或 EVALSHA 命令来执行这个 Lua 脚本。不过,与 KEYS 命令一样,如果数据量很大,执行这样的 Lua 脚本也可能会造成阻塞。

以下是服务器运行需要

bash 复制代码
redis-cli -h <host> -p <port> -a <password> EVAL "local keys = redis.call('KEYS', 'memberCardData:*') if next(keys) ~= nil then redis.call('DEL', unpack(keys)) end return #keys" 0

EVAL

EVAL 是 Redis 提供的一个命令,用于执行 Lua 脚本。它允许你在 Redis 服务器上直接运行 Lua 代码,这在需要复杂逻辑或批量操作时非常有用。Lua 脚本在 Redis 内部是原子性执行的,也就是说,在脚本执行期间不会被其他客户端的请求打断。

shell 复制代码
EVAL script numkeys [key [key ...]] [arg [arg ...]]

script: 要执行的 Lua 脚本(作为一个字符串传递)。

numkeys: 脚本中涉及的键的数量。这些键会被传入到 Lua 脚本中的 KEYS 数组中。

key \[key ...\]\]: 涉及的键列表,按照它们在 numkeys 中指定的顺序排列。 \[arg \[arg ...\]\]: 传递给 Lua 脚本的额外参数,这些参数会被传入到 Lua 脚本中的 ARGV 数组中。

相关推荐
qyhua3 小时前
【Linux运维实战】彻底修复 CVE-2011-5094 漏洞
linux·运维·安全
Andya_net4 小时前
网络安全 | 深入了解 X.509 证书及其应用
服务器·安全·web安全
九皇叔叔4 小时前
Linux Shell 正则表达式中的 POSIX 字符集:用法与实战
linux·运维·正则表达式
007php0074 小时前
百度面试题解析:微服务架构、Dubbo、Redis及其一致性问题(一)
redis·百度·docker·微服务·容器·职场和发展·架构
東雪蓮☆5 小时前
K8s 平滑升级
linux·运维·云原生·kubernetes
AKAMAI5 小时前
数据孤岛破局之战 :跨业务分析的难题攻坚
运维·人工智能·云计算
长安城没有风5 小时前
从入门到精通【Redis】Redis 典型应⽤ --- 分布式锁
数据库·redis·分布式
东巴图5 小时前
JavaScript性能优化实战大纲性能优化的核心目标
运维·matlab
站长朋友6 小时前
【邀请函】锐成信息 × Sectigo | CLM - SSL 证书自动化运维解决方案发布会
运维·自动化·ssl·clm·sectigo·47天ssl证书
qq_183802876 小时前
Linux内核idr数据结构使用
linux·运维·服务器