开发经验redis实现共同好友功能

Posted 叁滴水

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了开发经验redis实现共同好友功能相关的知识,希望对你有一定的参考价值。

背景

​ 微信朋友圈的点赞、评论,只能看到自己好友的信息。这就涉及到了一个共同好友的概念,通过redis的set集合可以很轻松的实现此功能。

共同好友实现思路

每个人的好友存放在set集合中。key的名字为friend_{userId}。如下图:

image-20210526103214584

  • 用户1的好友为2,3,4
  • 用户2的好友为1,3,4
  • 用户3的好友为1,4,5

交集

用户1和2是好友。他们的共同好友可以通过他们的交集获取。

image-20210526105209566

image-20210526104402063

redis命令示例:

127.0.0.1:6379> sadd friend_1 2 3 4
(integer) 3
127.0.0.1:6379> sadd friend_2 1 4 5
(integer) 3
127.0.0.1:6379> SINTER friend_1 friend_2
1) “4”

  • sadd 将一个或多个成员元素加入到集合中,已经存在于集合的成员元素将被忽略。命令详解
  • SINTER 返回给定所有给定集合的交集。命令详解

并集

获得所有的好友信息。

image-20210526105240580

127.0.0.1:6379> SUNION friend_1 friend_2
1) “1”
2) “2”
3) “3”
4) “4”
5) “5”

差集

可以用户好友推荐。差集出来的用户推荐给用户2。

image-20210526105457095

127.0.0.1:6379> sadd friend_1 2 3 4
(integer) 3
127.0.0.1:6379> sadd friend_2 1 4 5
(integer) 3
127.0.0.1:6379> SDIFF friend_1 friend_2
1) “2”
2) “3”

  • SDIFF 返回第一个集合与其他集合之间的差异。命令详解

更多set命令说明:

序号命令及描述
1SADD key member1 [member2] 向集合添加一个或多个成员
2SCARD key 获取集合的成员数
3SDIFF key1 [key2] 返回给定所有集合的差集
4SDIFFSTORE destination key1 [key2] 返回给定所有集合的差集并存储在 destination 中
5SINTER key1 [key2] 返回给定所有集合的交集
6SINTERSTORE destination key1 [key2] 返回给定所有集合的交集并存储在 destination 中
7SISMEMBER key member 判断 member 元素是否是集合 key 的成员
8SMEMBERS key 返回集合中的所有成员
9SMOVE source destination member 将 member 元素从 source 集合移动到 destination 集合
10SPOP key 移除并返回集合中的一个随机元素
11SRANDMEMBER key [count] 返回集合中一个或多个随机数
12SREM key member1 [member2] 移除集合中一个或多个成员
13SUNION key1 [key2] 返回所有给定集合的并集
14SUNIONSTORE destination key1 [key2] 所有给定集合的并集存储在 destination 集合中

以上是关于开发经验redis实现共同好友功能的主要内容,如果未能解决你的问题,请参考以下文章

hadoop实现求共同好友

微服务Spring Boot 整合 Redis 实现 好友关注

Redis实战之好友关注功能

Redis实战之好友关注功能

Redis之Set 集合

IOS开发-OC学习-常用功能代码片段整理