将 LUA 脚本注册为在指定事件( redis-key,操作 )发生时触发

我能不能让一个 LUA 脚本成为关系型数据库中的 TRIGGER 。例如,在向键为“TIMELIST”的列表追加或rpush之后,会触发一个Lua脚本对列表执行一些操作?

我快速浏览了一下 REDIS 文档中的 lua-script 部分,发现似乎脚本只能显式执行。我的想法是否不可能?

扩展: 如果上面的想法不可行。我应该采取什么措施来解决这个问题。我有一个排序列表来存储每日配额。我使用

> ZADD 'TIMELIST' <TS> <QUOTA>

来添加带有日期权重的新配额。我希望有序列表充当一个有界列表,仅维护最后7天的配额。我不使用LTRA​​M在普通redis-list上,因为配额在时间轴上可能有间隔。哈希表也不适用,因为出于某些原因,我必须使 TRUNCATION 操作在访问 REDIS 的应用程序中不可见。

我是一个Redis新手。有什么建议吗?谢谢!

点赞
用户3160475
用户3160475

不,这是不可行的。然而,你可以很容易地使用一个脚本来执行操作(LPUSHZADD 等)以及任何额外的触发器逻辑。

2017-03-28 02:32:50
用户4863726
用户4863726

你可以使用ZREMRANGEBYRANK来删除旧元素。

redis> ZADD myzset 1 "one"
(integer) 1
redis> ZADD myzset 2 "two"
(integer) 1
redis> ZADD myzset 3 "three"
(integer) 1
redis> ZREMRANGEBYRANK myzset 0 1
(integer) 2
redis> ZRANGE myzset 0 -1 WITHSCORES
1) "three"
2) "3"
redis>
2017-03-28 09:59:04
用户3629596
用户3629596

有一个关于 Redis 的有趣发展涉及到这种“触发器”。你可以通过以下方式实现你想要的效果:

Redis Key Space Notifications(当事件发生时得到通知-例如将一个键添加到你的集和有序集合中),然后运行一个内部 Redis 模块(在版本 5 中新添加)根据某些条件从集合中执行 ZREM - 有效地拥有了一个 Redis“触发器”。

技术上讲,你可以只使用 Key Space Notifications 选项发送一个 pub/sub 事件(在 Redis 中)-但是如果你没有订阅该事件的订阅者,你可能会错过该事件(Redis 中的 pub/sub 事件不具有持久性)。

缺点是你必须用 C/C++ 代码编写该模块,并验证它是否正常工作。

2019-06-19 08:33:16