卧槽:油管用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亿用户。
➡️