Rails和缓存,在memcache和redis之间切换是否容易?

是否有一个共同的api,如果我在Redis或Memcached之间切换,我不需要更改我的代码,只需配置设置?

只要您不自己初始化Memcached客户端但依赖于Rails.cache通用API,从Memcached切换到Redis只需要安装redis-store并更改配置

 config.cache_store = :memcached_store 

 config.cache_store = :redis_store 

有关更多信息Rails.cache 。

我讨厌弄乱你的目标,但我建议不要在memcached上使用redis来进行通用的rails缓存。

我在一个大型rails应用程序中广泛使用redis和resque,我认为将缓存,原始redis和resque合并为一个很好。 我遇到了一些大问题:

  1. 首先,它更慢。 它可能完全是我的特定用途,redis-store库或redis本身。 我不打算讨厌任何东西,你的里程可能会有所不同,但是当memcached“正常工作”时,很多时候会把很多时间转换成redis
  2. Memcached很不错,因为添加服务器并使用一致性哈希来实现目标非常容易。 Redis也有这个,但根据我的经验,很难同时将redis视为我应用程序某些部分的单片数据存储区,而其他部分则将其视为分布式,持续散列的缓存存储块。

祝你的项目好运。 我喜欢redis和memcached并在我的所有项目中使用它们,但是我让一个人做它作为kick-ass数据结构服务器的工作,让另一个人在缓存中蠢蠢欲动。

Redis的整洁部分包括缓存“基于列表”的东西 – 在应用程序中发生的事情中从这个列表中推送/弹出内容。

而不是从memcached中反序列化大值,编辑它,然后重新序列化它。

这将在自定义filter中的ruby代码中完成,而不是基本的rails缓存。