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合并为一个很好。 我遇到了一些大问题:
- 首先,它更慢。 它可能完全是我的特定用途,redis-store库或redis本身。 我不打算讨厌任何东西,你的里程可能会有所不同,但是当memcached“正常工作”时,很多时候会把很多时间转换成redis
- Memcached很不错,因为添加服务器并使用一致性哈希来实现目标非常容易。 Redis也有这个,但根据我的经验,很难同时将redis视为我应用程序某些部分的单片数据存储区,而其他部分则将其视为分布式,持续散列的缓存存储块。
祝你的项目好运。 我喜欢redis和memcached并在我的所有项目中使用它们,但是我让一个人做它作为kick-ass数据结构服务器的工作,让另一个人在缓存中蠢蠢欲动。
Redis的整洁部分包括缓存“基于列表”的东西 – 在应用程序中发生的事情中从这个列表中推送/弹出内容。
而不是从memcached中反序列化大值,编辑它,然后重新序列化它。
这将在自定义filter中的ruby代码中完成,而不是基本的rails缓存。
- Memcache Stats不使用Rails.cache.stats输出… Rails / Heroku
- 当memcached中有命中时,如何让caches_action设置expires头?
- 当Memcachier达到缓存限制时,Heroku请求超时
- Rails Cache Key生成为ActiveRecord :: Relation
- 仅对单个模型使用缓存资金?
- 我们如何在Memcached读取上阻止Ruby on Rails,以免它占用CPU?
- 如何在Rails中缓存Model对象?
- 如何使用Dalli更新MemCached中的到期时间?
- Heroku / Memcache / Rack :: Cache Stats