Cloudflare 如何将 Quicksilver 迁移到多级缓存并处理数十亿个请求(cloudflare使用教程)

作者 | Renato Losio

译者 | 王强

Cloudflare 的工程团队最近分享了他们如何将公司内部的全局键值存储 Quicksilver 过渡到分层缓存架构的故事。他们介绍了他们逐渐从“每一处都存储全部内容”的策略转变为采用分布式缓存系统的旅程。这一变化提高了存储效率,同时保证了一致性和边缘的低延迟读取性能。

在过去几年里,Cloudflare 从现在被称为 Quicksilver V1 的系统过渡到了新的分层缓存系统 Quicksilver V2,后者只使用了少数『服务器』来存储数据。这两篇文章描述了他们如何实现分层缓存架构的过程,这个过程需要团队迁移数十万个实时数据库,同时每秒服务数十亿个请求。

Quicksilver 是 Cloudflare 内部开发的一种键值存储,用于实现快速的全局复制,并在该公司全球众多『数据中心』中实现低延迟访问。它最初设计为分发各种配置的全局系统,随着时间的推移,它演变成了许多 Cloudflare 服务和产品(包括他们的 DNS、CDN 和 WAF)的基础存储系统。

Quicksilver v1 在全局每个『服务器』上都存储完整的数据集,结果消耗了大量磁盘空间,1.6TB 的数据集在仅仅一年内就增长了 50%,意味着 Cloudflare 网络中的可用存储即将耗尽。向新方案的迁移始于 Quicksilver v1.5,这是一个引入代理和复制『服务器』角色的解决方案,它让磁盘占用减少了 50%。

在最新的 v2 实现中,Cloudflare 引入了多级缓存策略。最新架构的特点是本地的每『服务器』一份缓存、『数据中心』范围内的分片缓存和在专用存储节点上的完整数据集副本,以及将未命中缓存分散在『服务器』之间的响应式预取。内存使用和冷缓存问题导致 Cloudflare 选择使用 RocksDB 的持久存储,而不是基于内存的缓存,并使用基于这一引擎的压缩过滤器进行驱逐。

Cloudflare 的系统『工程师』 Anton Dort-Golts 和 Marten van de Sanden 解释了为什么向后兼容性和顺序一致性很重要:

Quicksilver 从一开始就为客户提供了顺序一致性……我们亲身体会了海勒姆定律,Quicksilver 在公司内部采用得如此广泛,以至于我们在早期版本中引入的每个属性现在都依赖其他团队。这意味着更改行为将不可避免地破坏现有特性并引入错误。

新架构通过多版本并发控制(MVCC)和滑动窗口方法来处理异步复制挑战,从而保持顺序一致性。

从旧架构到 Quicksilver v2 的转变解决了 Cloudflare 之前在 330 个城市网络中遇到的关键瓶颈,同时保持了 1.6TB 数据集的亚毫秒处理性能(该数据集包含五十亿个键值对)。根据作者的说法,Quicksilver 目前对 90% 的请求可在 1 毫秒内响应,99.9% 的请求在 7 毫秒内响应。大多数请求只返回几个键,而其他请求返回数百甚至更多的键。Dort-Golts 和 van de Sanden 补充说:

我们的键空间被分成了多个分片。『数据中心』中的每个『服务器』被分配了一个分片。这些分片不是包含它们键空间部分的完整数据集,而是包含它的一片缓存。这些缓存分片由『数据中心』内的所有未命中缓存来填充。这一切组成了一个使用分片分布的,『数据中心』层面的缓存系统。

Cloudflare 通过维护本地每个『服务器』一块缓存以及『数据中心』级别的缓存来解决数据本地性问题,『数据中心』中的所有『服务器』都包含它们的本地缓存,和分片缓存的一个物理缓存分片。每个请求的键首先在『服务器』的本地缓存中查找,然后在『数据中心』范围的分片缓存中查找。如果两个缓存都未命中键,则在存储节点之一上查找。作者在文章最后分享了一些有多个缓存层的测试结果:

添加第二缓存层后,可以在『数据中心』内解决的键的百分比显著提高。表现最差的实例具有高于 99.99% 的缓存命中率。所有其他实例的缓存命中率高于 99.999%。

代理和副本之间的 99.9 百分位延迟几乎没有差异,由于磁盘数据集较小,代理偶尔优于副本。

特别声明:[Cloudflare 如何将 Quicksilver 迁移到多级缓存并处理数十亿个请求(cloudflare使用教程)] 该文观点仅代表作者本人,今日霍州系信息发布平台,霍州网仅提供信息存储空间服务。

猜你喜欢

红米豁出去了,7000mAh+长焦+十面抗摔+IP69防水,512GB仅1785元(红米有点狠)

在影像方面,这款红米Note 15 Pro+也下了狠功,后置使用了5000万像素的光影猎人800主摄,拥有11.55英寸的感光面积,还拥有OIS光学防抖,同时拥有5000万像素的直立长焦三星JN5,它能实…

红米豁出去了,7000mAh+长焦+十面抗摔+IP69防水,512GB仅1785元(红米有点狠)

我心也曾逐月华 沈如嫣贺京澜许宁朝 那一日,任凭沈如嫣如何反抗,最后还是被摁在了那块凹凸不平的木板上。(我心曾经照明月)

说着,他一把勾过沈如嫣的细腰,死死压进怀里,嗓音戏谑:“到时候,我跟朝朝的婚礼,一定让你坐主桌......” 她心里闷痛,却仍是勾唇笑了下:“我被这帮人播放视频,诬陷挑衅,脖子现在痛到动不了,谁来给我认错?…

我心也曾逐月华 沈如嫣贺京澜许宁朝 那一日,任凭沈如嫣如何反抗,最后还是被摁在了那块凹凸不平的木板上。(我心曾经照明月)

夜光熊猫!TS「联名倒钩」刚刚突袭!这次效果更炸裂!(夜光熊猫是什么皮料)

无疑是今年 TS x Jordan「倒钩家族」中最吸引眼球的一款,Travis Scott 与好兄弟 Chase B共同打造的「联名夜光款」Jordan Jumpman Jack 确实够炸裂,终于迎来正式登…

夜光熊猫!TS「联名倒钩」刚刚突袭!这次效果更炸裂!(夜光熊猫是什么皮料)

不得了!忠华瑞揭秘清式红木材质搭配的实用建议!(忠华集团实力)

在选择材质时,要根据家具的用途、风格以及预算来综合考虑。和谐统一是指在搭配材质时,要使不同材质在颜色、纹理、质地等方面相互协调,形成整体的美感。通过合理的材质选择、遵循搭配原则以及把握好搭配细节,才能打造出具…

不得了!忠华瑞揭秘清式红木材质搭配的实用建议!(忠华集团实力)

影片被疯传!李俊昊大前辈风范MAX帮张员瑛解围!绅士细节圈粉无数(李衲 电影)

得知是工作人员示意后,李俊昊没有丝毫犹豫,宛如一位坚定的守护者,迅速示意张员瑛回到后排与队友们站在一起。这段视频在网络飞速传播,浏览量突破百万,网友们不约而同地赞叹:这正是一位懂得照顾后辈、绅士风范十足的大…

影片被疯传!李俊昊大前辈风范MAX帮张员瑛解围!绅士细节圈粉无数(李衲 电影)