redis - 构建redis键

标签 redis

我以前从未使用过 Redis,但我一直想用,而且我当前的用例似乎很合适。

我实际上是在尝试构建一个消息传递应用程序。当一个用户向另一个用户发送消息时,发送到服务器的数据如下所示:

{ from_user: 'alice', for_user: 'bob', payload: 'hello!', timestamp: 1404695488 }

然后我希望能够做的是:

  1. 给定 alice,查看所有向 alice 发送了一条 alice 尚未阅读的消息的用户

  2. 给定 alice 和 bob,返回 bob 发送给 alice 的所有消息的列表,我可以从中弹出 alice 已阅读的内容。一旦 alice 阅读了 bob 发送给她的所有消息,#1 将不会返回 bob。

如果我还不够清楚,请告诉我。此外,我选择 Redis 的另一部分原因是因为这是一个消息传递应用程序,我想利用 Pub/Sub 功能。

最佳答案

解决此问题的一种方法是在发送消息时更新以下数据结构:

  1. 未读消息:为存储他/她的未读消息的每个用户保留一个排序集。使用时间戳作为分数并将时间戳和有效负载连接为成员,例如:ZADD unread-messages:bob:alice 1404695488 "1404695488:hello!"

  2. 未读消息的发件人:为存储发件人的每个用户保留一个集合,即:SADD unread-senders:bob alice。`

要向 Bob 显示所有向他发送消息但他尚未阅读的用户,请执行 SMEMBERS unread-senders:bob

当 Bob 阅读消息时:

  1. 将其从未读排序集中移除 - ZREM unread-messages:bob:alice "1404695488:hello!"
  2. 使用 EXISTS unread-messages:bob:alice 检查 unread-messages 键是否存在 - 如果没有任何消息,Redis 将删除它。如果 key 被删除,则从未读发件人集中删除相关用户:SREM unread-senders:bob alice

注意:您想要执行实现添加未读消息并以原子方式删除它的操作,因此为此目的使用 MULTI/EXEC block 或 Lua 脚本。

关于redis - 构建redis键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24601987/

相关文章:

redis - 替换大型 Redis key 的最有效方法

ruby-on-rails - 如果我不在 after_fork 中 $redis = Redis.new 会发生什么?

angularjs - 是否可以使用 Redis 作为字典和 AngularJs 来实现拼写检查功能?

ruby - 有没有办法让 resque-web 与 Redis To Go 托管的 redis 实例一起工作?

redis - 为什么启动webdis会连接多个redis客户端?

redis - 大尺寸的redis列表会将数据存储在集群中的多个redis节点中吗?

redis - 如何限制 Redis 排序集中的项目数

java - 我如何在 spock 测试中使用 redisService 我需要清理 redis 数据库以进行设置和清理

redis - 有没有办法使用 Docker secrets 从/run/secrets/redis-pass 读取并设置 redis --requirepass 标志?

Redis 缓存服务器 - 多网站环境