<返回更多

系统有万亿条消息怎么存储?

2023-12-26  微信公众号  ByteByteGo
加入收藏

我们如何设计一个能存储数万亿条信息的系统?

Discord 的消息存储演进给我们提供了真实案例参考。

下图显示了 Discord 消息存储的演变过程:MongoDB -> Cassandra -> ScyllaDB

系统有万亿条消息怎么存储?图片

第一阶段

2015 年,Discord 的第一个版本建立在单个 MongoDB 之上。2015 年 11 月左右,MongoDB 存储了 1 亿条消息,其内存无法再容纳数据和索引。延迟变得不可预测。消息存储需要转移到另一个数据库。这时 Cassandra 被选中。

第二阶段

2017 年,Discord 拥有 12 个 Cassandra 节点,存储了数十亿条消息。

2022 年初,Discord 拥有 177 个 Cassandra 节点,存储了数万亿条消息。此时,延迟再次变得难以预测,维护的成本也变得过于昂贵。

造成这一问题有几个原因:

  1. Cassandra 使用 LSM 树作为内部数据结构。读取比写入更昂贵。在一台拥有数百名用户的服务器上,可能会有很多并发读取,从而导致热点问题。
  2. 维护集群(如压缩 SSTables)会影响性能。
  3. 垃圾回收会导致明显的延迟

第三阶段

这时,Discord 重新设计了消息存储的架构

  1. 采用集中式的数据服务,其使用单体 API来访问,并用 Rust 重写。
  2. 采用基于 ScyllaDB 的存储。ScyllaDB 是用 C++ 编写的 Cassandra 兼容数据库。

新架构的优势在于:

为了进一步保护 ScyllaDB,Discord 针对数据服务还做了以下优化:

优化后的系统性能大大提高:

该系统可轻松应对世界杯流量高峰。

本文参考 Discord blog。

关键词:存储      点击(8)
声明:本站部分内容来自互联网,如有版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
▍相关推荐
更多存储相关>>>