专栏名称: 聊聊架构
在这里煮酒聊架构。
目录
相关文章推荐
美团技术团队  ·  可信实验白皮书系列03:随机对照实验 ·  2 天前  
架构师之路  ·  爸爸!除了你,沈括,沈万三... ... ·  3 天前  
字节跳动技术团队  ·  掘金 AI 编程社区- 人人都是 AI 编程家竞赛 ·  昨天  
51好读  ›  专栏  ›  聊聊架构

Reddit是如何使用Memcached来存储3TB缓存数据的?

聊聊架构  · 公众号  · 架构  · 2017-01-24 09:57

正文

请到「今天看啥」查看全文


新版本的Memcached可能支持slab_automove功能,不过这是后话了。

Reddit的缓存类型

接下来我们来看看Reddit的几种缓存类型。

数据库对象缓存(thing-cache)

数据库对象缓存是Reddit最大的缓存池。这些对象是无schema的,开发人员可以很容易地对这些对象添加新属性,而无需对数据库schema进行变更。这些对象包括用户评论、链接和账户等等。该类型缓存是Reddit最繁忙也最有用的缓存,命中率高达99%。

主缓存(cache-main)

主缓存是Reddit第二大缓存池。这个缓存是一般性的缓存,里面存放的所有用来展示/r/all的结果集。不过从表格中可以看到,这个缓存的命中率并不高,大概只有25%左右。

渲染缓存(cache-render)

第三大缓存用来存放渲染过的页面模板或页面片段。这个缓存相对安全,就算发生失效,也不会对系统造成太大影响。它的命中率只有大概50%左右,毕竟页面信息需要不断更新,所以渲染过的页面模板或片段也需要更新。再则,就算这个缓存失效,也不会给数据库负载带来多大影响,因为用来渲染页面的上下文内容已经在其它独立的缓存中加载过了。不过,因为缓存的key是基于上下文内容生成的,如果key发生变化,模板就需要重新缓存,这个需要消耗额外的CPU,也会使页面响应时间变长。







请到「今天看啥」查看全文