redis通过lua脚本,获取满足key pattern的所有值

我们知道,redis提供了keys命令去获取所有满足格式的key,如我们键入命令

keys "user*"

将得到所有以user开头的key
keys *user
然后执行 mget命令可以获取多个key的值,如
在这里插入图片描述
但如果满足条件的key过多,我们要将所有key拿到,再用mget去拿到所有值则为相对比较麻烦,因此可以借助xargs

redis-cli keys "user*"|xargs redis-cli mget获取到所有key的值
在这里插入图片描述
也可以执行lua脚本local keys = redis.call('keys', KEYS[1]); return redis.call('mget',unpack(keys));
在这里插入图片描述
如果需要同时输出key和value,可以调整lua脚本
eval "local keys = redis.call('keys', KEYS[1]); local values = redis.call('mget',unpack(keys)); local keyValuePairs = {};for i = 1, #keys do keyValuePairs[i] = keys[i]..':'..values[i] end; return keyValuePairs;" 1 "user*",
最后输出结果如下
在这里插入图片描述

这里简单普及下redis eval命令 和lua脚本基本用法
eval命令的格式如下
eval script numkeys key1 key2 arg1 arg2
scriptlua脚本,字符串,首尾引号必须,脚本中的双引号全改为单引号即可
numkeyskey的数量,key和arg都是传入lua脚本的参数,下面提到
key1,key2指具体key值,上面的numkeys有多少个,这里的key就有多少个
arg1,arg2key结束后就是arg。
eval "return 'hello'" 3 1 2 3 4 5 6 7中第一个3为key的数量,即后面的123为key,4567为arg。
在脚本中可以用KEYS[2]表式第二个参数,ARGV[2]表示第2个参数值,比如我们修改上面return 'hello'的值
eval "return KEYS[3]" 3 1 2 3 4 5 6 7将返回第3个参数,即3
在这里插入图片描述
eval "return ARGV[2]" 3 1 2 3 4 5 6 7将返回第二个值,即5
在这里插入图片描述
在lua脚本中使用redis.call('get',...)可调用redis命令,我们将上面的lua脚本格式化,解释如下 :
lua中用–表示注释

--local为局部变量,没有local关键字,则视为全局变量
--redis.call是调用redis命令,下面使用了keys命令
--KEYS[1]为第1个参数,lua数组下标从1开始
local keys = redis.call('keys', KEYS[1]);
--下面通过mget获取所有key的值,call后面是可变长参数,unpack是将数组变成可变长参数
local values = redis.call('mget', unpack(keys));
--定义返回结果
local keyValuePairs = {};
--#keys是获取keys的长度,这里作了个for循环,将key与value对应起来
--lua中字符串拼接是用..
for i = 1, #keys do
    keyValuePairs[i] = keys[i] .. '\t' .. values[i]
end;
--返回结果
return keyValuePairs;
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Redis集群中,Lua脚本是在执行脚本的那个节点上执行的,无法直接指定运行的节点。但是,我们可以通过自定义分片算法,将相同的键映射到同一个节点上,从而实现脚本在指定节点上执行。 对于获取系统时间的Lua脚本,在Redis中可以使用内置的time()函数来获取当前时间。例如,以下脚本可以返回当前时间戳: ``` return redis.call('time')[1] ``` 如果要让该脚本在指定节点上执行,可以使用自定义分片算法将相同的键映射到该节点上。例如,可以使用JedisCluster的setSlot()方法将键“time”映射到指定的节点上,然后再执行Lua脚本。示例如下: ``` JedisCluster jedisCluster = new JedisCluster(nodes, config); String script = "return redis.call('time')[1]"; String key = "time"; int slot = JedisClusterCRC16.getSlot(key); jedisCluster.setSlot(key, slot); String result = jedisCluster.eval(script, 0, key).toString(); ``` 在这个例子中,我们使用JedisClusterCRC16的getSlot()方法获取键“time”对应的槽号,然后使用setSlot()方法将键“time”映射到指定的节点上。最后,我们使用eval()方法执行Lua脚本,并指定需要执行脚本的键。 需要注意的是,在使用自定义分片算法时,需要保证相同的键映射到同一个节点上执行,否则会导致脚本执行结果不一致的问题。同时,由于时间戳是与具体时间无关的相对,因此在不同节点上执行脚本得到的时间戳可能会有微小的误差。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值