关注模块的总体实现方式和点赞模块其实差不多,包含如下几个功能:
关注的目标可以是用户、帖子等,在实现时将这些目标抽象为实体就行了,目前为止 Echo 中只实现了关注用户功能。
大概的流程图如下:
1)关注、取消关注:
2)关注列表、粉丝列表:
先达成一个共识:若 A 关注了 B,则 A 是 B 的粉丝(Follower),B 是 A 的目标(Followee)
为此,我们需要两张 Redis 表,一张用来存储某个用户关注的实体相关信息(做出关注这个事件的一定是人嘛,不可能说一张帖子去关注了一个用户,所以主语一定是用户),另一张用来存储某个实体拥有的粉丝(粉丝一定是用户)相关信息。
关于 Redis Key 规范,可以翻看Echo 的点赞模块是怎么做的这篇教程,这里我们同样需要用到 Redis 的数据结构 zset 天然的去重性。
1)第一张表:将某个用户关注的实体相关信息存储在 zset 中:key 是 followee:userId:entityType
,对应的 value 是 zset(entityId, now)
,以关注的时间进行排序。
比如说 followee:111:3
对应的 value (20, 2020-02-03-xxxx)
,表明 id = 111 的用户关注了实体类型为 3 即人(用户),该实体的 id 是 20,关注该帖子的时间是 2020-02-03-xxxx。