为了账号安全,请及时绑定邮箱和手机立即绑定

Redis 如何使用 golang 监听 1000 到 10,000 个列表中的变化?

Redis 如何使用 golang 监听 1000 到 10,000 个列表中的变化?

Go
偶然的你 2021-12-07 15:16:12
我有 1000 到 10,000 个键存储在 Redis 中,它们的值类型是列表。当一个新项目添加到任何一个现有列表时,我需要通知我的 golang 程序。收到通知后,我需要生成一个新的 goroutine 并执行一个小操作。我正在将 redigo 用于 redis 连接池。在不重载 Redis 实例的情况下,解决此问题的最佳方法是什么?
查看完整描述

2 回答

?
慕勒3428872

TA贡献1848条经验 获得超6个赞

您可以启用 Redis 的键空间通知并订阅您感兴趣的键/模式的相关事件。

更多细节可以在文档中找到:http : //redis.io/topics/notifications


查看完整回答
反对 回复 2021-12-07
?
郎朗坤

TA贡献1921条经验 获得超9个赞

我还没有尝试过这个,但作为推测,我会使用 Redis 的 Lua 来实现 2 个新命令 - MSR_PUSH 和 MSR_POP - 它们将分别执行以下操作:


-- MSR_PUSH

redis.call("PUSH", KEYS[1], ARGV[1])

redis.call("PUBLISH", "notify", KEYS[1])

和:


-- MSR_POP

local v = redis.call("POP", KEYS[1])

if v then

  redis.call("PUBLISH", "notify", KEYS[1])

end

return v

因此,这些 Lua 脚本会像往常一样更新列表,但也会将更新的键名发布到通知发布/订阅,然后允许监视脚本 (golang) 执行某些操作。你也可以推到另一个队列,然后长时间轮询。


这个链接有更多关于 Lua with Redis 的信息:https : //www.redisgreen.net/blog/intro-to-lua-for-redis-programmers/


查看完整回答
反对 回复 2021-12-07
  • 2 回答
  • 0 关注
  • 431 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信