一、背景最近接到一个需求,用一句话来说就是:展示关注人发布的动态 , 这个涉及到 feed 流系统的设计 。本文主要介绍一个一般企业可用的 Feed 流解决方案 。

文章插图
二、相关概念下面先介绍一下关于 Feed 流的简单概念 。
1.什么是 feed 流
- Feed:Feed 流中的每一条状态或者消息都是 Feed,比如微博中的一条微博就是一个 Feed 。
- Feed流:持续更新并呈现给用户内容的信息流 。每个人的朋友圈,微博关注页等等都是一个 Feed 流 。
- Timeline:按发布的时间顺序排序,产品如果选择 Timeline 类型,那么就是认为 Feed 流中的 Feed 不多 , 但是每个 Feed 都很重要 , 都需要用户看到 。类似于微信朋友圈 , 微博等 。
- Rank:按某个非时间的因子排序,一般是按照用户的喜好度排序,一般用于新闻推荐类、商品推荐等 。
1.Feed 流初始化Feed 流【关注页 Feed 流】的初始化指的是,当用户的 Feed 流还不存在的时候,为该用户创建一个属于他自己的关注页 Feed 流,具体怎么做呢?其实很简单,遍历一遍关注列表 , 取出所有关注用户的 feed,将 feedId 存放到 redis 的 sortSet 中即可 。这里面有几个关键点:
- 初始化数据:初始化的数据需要从数据库中加载出来 。
- key 值:sortSet 的 key 值需要使用当前用户的 id 做标识 。
- score 值:如果是 Timeline 类型 , 直接取 feed 创建的时间戳即可 。如果是 rank 类型,则把你的业务对应的权重值设进去 。
- 关注的用户发布新的 feed:
- 关注的用户删除 feed 。
- 用户新增关注 。
- 用户取消关注 。
- 推:A用户发布新的动态时,要往 A用户所有的粉丝 feed 流中推 。
- 拉:A用户发布新的动态时 , 先不进行推送 , 而是等 粉丝进来的时候,才主动到 A用户的个人页TimeLine 拉取最新的 feed,然后进行一个 merge 。如果关注了多个大V,可以并发的向多个大V 个人页TimeLine 中拉取 。
- 先从关注列表中读取到自己的粉丝列表,以及判断自己是否是大V 。
- 将自己的Feed消息写入个人页Timeline 。如果是大V , 写入流程到此就结束了 。
- 如果是普通用户,还需要将自己的Feed消息写给自己的粉丝,如果有100个粉丝,那么就要写给100个用户 。
- 先去读取自己关注的大V列表
- 去读取自己的 Feed 流 。
- 如果有关注的大V,则再次并发读取每一个大V的个人页Timeline,如果关注了10个大V , 那么则需要10次访问 。
- 合并2和3步的结果,然后按时间排序,返回给用户 。
5.推模式如果只是用推模式了,则会变的比较简单:
推荐阅读
- 苹果手机轻松实现微信双开分身
- Redis内存碎片:深度解析与优化策略
- SpringBoot如何实现热部署?
- Redis中的三种特殊类型
- 桶排序:原理、性能分析与 Java 实现
- Redis中的Big Key问题:排查与解决思路
- 如何去除冰箱异味? 如何去除冰箱异味
- 基于牛顿求根法,新算法实现并行训练和评估RNN,带来超10倍增速
- CORS 跨域资源共享在Spring Boot中的实现
- 使用Beacon API实现高效数据传输和用户行为分析
