feed留,单聊群聊,系统通知,状态同步,到底是推还是拉?

  1. 云栖社区>
  2. 阿里云MVP>
  3. 博客>
  4. 正文

feed留,单聊群聊,系统通知,状态同步,到底是推还是拉?

初商南 2019-08-09 23:47:30 浏览150
展开阅读全文

今天抛一个话题,根据业务现象,一起讨论其后端实现是推还是拉?

一、feed流

可以理解为一个发布订阅业务,典型业务是微博(朋友圈)。你关注了姚晨的微博,姚晨发布了消息,你的主页能看到她最新发布的消息,这个场景是推送,还是拉取呢?

画外音:微博是弱关系,关注无需对方同意,粉丝可以无上限;朋友圈是强关系,好友需要对方同意,好友个数有上线。

如果推送,姚晨发布消息的时候,要把消息ID投递到所有粉丝的主页消息队列里,推送量巨大。

如果拉取,一来主页消息无法实时更新,二来每次刷新动作非常复杂:

拉取你关注人的list

拉取这些人的消息list

对于这些人的这些消息进行rank处理,例如按照时间排序

还无法对主页进行缓存,因为只要有关注人发布消息,主页内容就会变化

还得考虑“不看谁的消息”,以及“消息不给谁看”

...

是不是觉得有点烦?如果你是架构师,你会怎么做?

网友评论

登录后评论
0/500
评论
初商南
+ 关注
所属云栖号: 阿里云MVP