软件设计套路之推拉模式

推、拉是两种常见的数据分发模式。以微博为例:

  • 推:发微博时,遍历所有关注者,写入数据到对应的关注者数据表里。好处是,读取时直接读取数据库即可,即用写入时间换取读取时间。坏处是:
    • 如果微博发生变化,例如被删除,则需要再次进行处理
    • 如果关注者量非常大,写入非常耗时,非常的消耗存储
  • 拉:用户开始刷微博时,从所有关注的人的时间线里,把距离上次看到的微博全部加载出来,这种模式的好处与坏处则推相反。
  • 混合模式,使用一定的策略,混合上述两种模式。

使用这两种模式以及混合模式的系统还有:

  • 朋友圈
  • Linux网络收包时,可以由系统定时去polling,也可以由网卡发中断信号通知内核(前者的坏处是流量负载低时延迟大数据无法近实时被处理,后者的坏处是当流量负载高时,内核会被频繁中断)
  • 当推送系统涉及到写入群公告信息时
  • 订阅中心等诸如此类的应用

更多文章
  • Go Module 简明教程
  • 写了一个Telegram Bot:自动化分享高质量内容
  • ArchLinux 怎么降级 package ?
  • Vim打开很慢,怎么找出最慢的插件?怎么解决?
  • 为什么我选择放弃运营微信公众号?
  • Web后端工程师进阶指南(2018)
  • How to implement fork syscall in Golang?
  • macOS ansible 遇到 rsync: --chown=www-data: unknown option
  • 关于运营的思考-运营要怎么做?
  • Python中实现单例模式的n种方式和原理
  • Golang defer中修改返回值
  • Python dataclass 源码阅读与分析
  • gRPC-gateway 源码阅读与分析
  • 如何阅读源代码
  • 我心目中的配置中心应该怎么做?