如何在 Redis LUA 脚本中正确传递复合键?

我有一个使用键嵌套和键组合以不同前缀的 Redis 系统:

SET prefix-1:concrete-key-1 value-1
SET prefix-1:concrete-key-2 value-2
SET prefix-2:concrete-key-1 value-3
SET prefix-2:concrete-key-2 value-4
SET id-123 concrete-key-1
SET id-456 concrete-key-2
SET id-789 concrete-key-1

因此,通过使用 id-xxx<prefix>,我可以在 2 个命令中得到特定值

id-123 -> concrete-key-1
prefix-1 + concrete-key-1 -> value-1

为了减少 Redis 调用和流量量,我创建了一个在 Redis 端执行 getter 的小 LUA 脚本:

key = redis.call('GET', KEYS[1]);
return redis.call('GET', <prefix>..key);

问题是如何在这种情况下正确地传递前缀?

根据 Redis,我应该显式指定键作为 KEYS 参数:https://redis.io/topics/lua-api

我应该将它作为一个 key 传递吗?

key = redis.call('GET', KEYS[1]);
return redis.call('GET', KEYS[2]..key);

但是,没有独立的 <prefix> 键,它们都由 <prefix>:<key> 组成。那么,我应该将前缀作为参数传递吗?

key = redis.call('GET', KEYS[1]);
return redis.call('GET', ARGV[1]..key);

或者是否有其他方法可以使用脚本正确获取值?

原文链接 https://stackoverflow.com/questions/71203968

点赞
stackoverflow用户2395796
stackoverflow用户2395796

声明KEYS的目的是为了Redis Cluster能够将脚本路由到正确的服务器,并在尝试引用不同服务器上的键时快速失败。有关更多详细信息,请参见我在这里的答案。

因此,您的第一步是考虑所有可能的键组合是否都驻留在同一台服务器上。如果不是,则无论如何都无法运行脚本。

如果是这样,那么您当前的方案只需要在KEYS参数中传递id-123键就可以了。将前缀传递到KEYS中显然没有意义,因为它不是一个键,Redis也不知道该怎么做。无论是硬编码还是将其传递到ARGV中取决于您,就像调用函数时一样。

2022-02-21 14:07:53