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

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

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

一、feed流

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

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

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

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

拉取你关注人的list

拉取这些人的消息list

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

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

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

...

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

二、聊天消息

聊天消息又分为单聊和群聊,典型的业务是微信。和朋友小窗沟通是单聊,群内扯淡是群聊。

单聊,很容易想到是服务器推送,但浏览器里的聊天工具JS只能使用http式的request - response协议,又能不能保证消息的实时性呢?

群聊,一个群500个人,有人在线,有人离线,到底是推送,还是拉取呢?

如果是推送,1条消息将转变为500条消息,系统压力会异常之大。

如果是拉取,消息的实时性又该如何保障呢?

还有一个坑爹的需求,“钉钉”的群聊天消息“已读回执”,这个需求简单描述是:对于每一条你发出的每一群消息,你能够看到,多少人已读,多少人未读。这个群消息已读回执,猜猜看,又是怎么实现的呢?

三、系统通知

系统消息听上去比较泛,典型的业务是QQ的登录广告弹窗,以及登录后的右下角广告提示。

  • QQ每天首次登录后的新闻弹窗

拉取?第二次登录却又没有。

  • QQ运行过程中的QQ弹窗广告

推送?一次推送几千万条,会不会系统抖动?

或许,真实的实现方式或许与我们想的并不一样。

四、状态同步

玩桌面QQ时,收到过“你的好友XXOO登录了”的弹窗提示么?这是一个好友登录/登出状态的客户端同步。同理,群有500人,每个群友的在线/不在线状态又是怎么实现同步的呢?

推送?那一个用户登录退出都要推送N个好友?M个群友?

拉取?如何保证好友状态,群友状态的实时性?

画外音:好友/群友状态一致性是非常复杂的,移动的时代,索性引入“一律在线”的概念,微信的好友就不存在所谓“头像亮”和“头像灰”的概念了,客户端状态同步这一块复杂性有所降低。

看到产品功能,思考后面的技术实现,其实是很有意思的一件事。

究竟是推,还是拉?大伙怎么看。

还有其他业务场景的疑惑,也欢迎评论提问,有价值的问题,5月份逐条解答。

画外音:自从有了群消息已读回执,我再也不能装作不在线,领导的消息没看到了。

目录
相关文章
|
人工智能 供应链 监控
【AI 现况分析】AI 在机械制造领域的应用分析
【1月更文挑战第27天】【AI 现况分析】AI 在机械制造领域的应用分析
|
3月前
|
弹性计算 应用服务中间件 云计算
阿里云2026年最新【学生服务器】在哪申请?配置价格说明
阿里云2026年学生福利:完成学生认证,领取300元无门槛代金券,前往学生用券中心抵扣云服务器费用,即可免费获取。还可参与活动中心优惠,享38元/年起轻量服务器,配置丰富,续费同价,助力学生低成本入门云计算。
743 15
|
存储 机器学习/深度学习 网络协议
阿里云企业级ARM计算规格族简介:特点、场景与价格参考
Arm计算是指基于 ARM 架构的处理器进行的计算,本文将为您解析阿里云ARM云服务器的特点、适用场景,以及最新价格情况,以供了解和参考。
|
数据采集 Web App开发 API
虾皮(Shopee)商品详情数据接口详解
虾皮(Shopee)是东南亚与台湾领先的电商市场,为买卖双方搭建桥梁。本文介绍如何利用网页爬虫技术获取商品详情数据,适用于无API访问权限的情况。通过Python的`requests`和`beautifulsoup4`库,可从网页中提取信息。首先需安装上述库,然后使用示例代码发送HTTP请求并解析HTML。注意遵守虾皮的服务条款,应对可能的动态内容和反爬虫措施。对于API需求,建议查阅官方文档。
863 3
|
存储 前端开发 UED
React 面包屑组件 Breadcrumb 详解
面包屑导航是现代Web应用中常见的UI元素,帮助用户了解当前位置并快速返回上级页面。本文介绍如何使用React构建面包屑组件,涵盖基本概念、实现方法及常见问题。通过函数式组件和钩子,结合React Router动态生成路径,处理嵌套路由,并确保可访问性。示例代码展示了静态和动态面包屑的实现,帮助开发者提升用户体验。
783 73
|
前端开发 Python
Matplotlib 轴标签和标题
Matplotlib 轴标签和标题
473 6
|
前端开发 Java 关系型数据库
基于SSM的大学生兼职平台的设计与实现
基于SSM的大学生兼职平台的设计与实现
408 2
|
前端开发 JavaScript 开发者
React 组件化开发最佳实践
【10月更文挑战第4天】React 组件化开发最佳实践
533 4
|
运维 监控 安全
一文读懂什么是API
API全称Application Programming Interface,即应用程序编程接口,是一些预先定义的函数,或指软件系统不同组成部分衔接的约定,用于传输数据和指令,使应用程序之间可以集成和共享数据资源。
|
缓存 算法 Java
关于MyBatis的缓存详解
MyBatis 的缓存机制非常灵活,可以通过简单的配置来满足不同的性能需求。合理地使用缓存可以显著提高应用程序的性能,尤其是在处理大量数据库查询时。然而,开发者需要注意缓存的一致性和并发问题,特别是在使用可读写缓存时。
291 3

热门文章

最新文章