卧槽:油管用MySQL支持24.9亿用户

💡 原文中文,约1700字,阅读约需4分钟。
📝

内容提要

YouTube使用MySQL和Vitess解决了大规模用户扩展性问题。Vitess是一个由YouTube开发的数据库解决方案,通过添加缓存和预加载来加快MySQL复制速度。Vitess架构包括VTTablet、VTGate、键值数据库和VTctld。Vitess是用Go语言编写的,支持MariaDB。

🎯

关键要点

  • YouTube使用MySQL支持24.9亿用户。
  • Vitess是YouTube开发的开源数据库解决方案,解决MySQL扩展性问题。
  • 最初,PayPal的员工尝试创建约会网站,但转向创建YouTube。
  • YouTube通过MySQL主从复制拓扑扩展,但复制速度受限于单线程。
  • 通过添加缓存和预加载,YouTube加快了MySQL的复制速度。
  • 分区后,MySQL的事务和连接管理变得复杂,需要应用程序逻辑处理。
  • Vitess提供了一个抽象层,通过VTTablet边车服务器实现极端可扩展性。
  • Vitess架构包括VTTablet、VTGate、键值数据库和VTctld。
  • Vitess是用Go语言编写的,支持MariaDB。
  • YouTube能够使用Vitess和MySQL组合服务24.9亿用户。
  • 网友评论指出分片解决了60%的扩展问题,但管理分片路由仍然是挑战。
  • 2018年,YouTube停止使用MySQL,转而使用Vitess。
  • 在扩展或缩小服务器时,如何管理节点添加和删除是一个重要问题。
  • 2019年,YouTube用户数达到20亿,今天已增至27亿。
  • 没有任何数据库能够在不经过额外工作情况下处理24.9亿用户。
➡️

继续阅读