如何从redis-cli repl中删除Redis匹配模式中的所有键?

时间:2018-03-01 17:41:55

标签: caching redis redis-cli

我正在尝试使用redis-cli删除与前缀匹配的一串键。

我一直在研究如何在线进行此操作,我见过的最常见的建议是直接从命令行执行此操作,如下所示:

$ redis-cli [options] KEYS "prefix:*" | xargs redis-cli [options] DEL

但是,我更喜欢在<{em>} redis-cli工具中执行此操作,这样我每次都不需要在cli命令中传递hostname,port和auth参数删除与模式匹配的键。到目前为止,我已经尝试过:

  • DEL "prefix:*"
  • DEL KEYS prefix:*
  • DEL KEYS "prefix:*"
  • KEYS "prefix:*" | DEL
  • KEYS "prefix:*" DEL

有没有办法在 redis-cli工具中删除前缀下的所有键?命令行是实现此目的的唯一方法吗?

如果您希望我澄清更多信息,请随时发表评论。

2 个答案:

答案 0 :(得分:1)

您可以编写lua脚本来删除密钥。

local matches = redis.call('KEYS', ARGV[1])

local result = 0
for _,key in ipairs(matches) do
    result = result + redis.call('DEL', key)
end

return result 

将此文件本地保存为delete.lua并按如下方式运行:

$redis-cli script load "$(cat delete.lua)"

"efe4f6a74ff9baba16d039f892dd09174b9f5777"

那&#34; $(cat delete.lua)&#34;只是将我们的脚本变成一个引用的参数。重要的一点是返回的数字(以十六进制表示)。它是脚本的SHA1签名。我们可以使用它来使用redis-cli中的EVALSHA命令来调用脚本,如下所示:

EVALSHA efe4f6a74ff9baba16d039f892dd09174b9f5777 1 nil prefix:*

答案 1 :(得分:0)

在redis-cli中运行此命令:

EVAL "return redis.call('del', unpack(redis.call('keys', ARGV[1])))" 0 prefix:*

用所需的模式替换prefix:*。输出将是已删除键的数量。