ruby-on-rails – 在Rails中使用memcached的最佳做法?

随着我们应用程序中的数据库转换越来越耗时,我们已经开始使用memcached来减少传递给 MySQL的查询量.

总而言之,它工作正常,真的节省了大量的时间.

但由于缓存是“默默地出现”作为解决方案给应用程序更多的果汁,我们的很多模型现在包含这样的代码:

def self.all_cached

  Rails.cache.fetch('object_name') {

    find(

      :all,:include => [associations])

    }

end

这是越来越多的痛苦,因为填充和刷新缓存发生在应用程序的几个类.

现在,我想知道是否有更好的方法来抽象memcached逻辑,使其在所有需要的模型中更加强大和易于使用?

我正在想一些包含在所有需要的模块中的memcached模块.

但是在玩耍之前,我想:我们先来问专家:-)

谢谢

马特

解决方法

我建议检查现有的插件,两个大的是 cache_fucache money.对于您想要加载模型与其关联超出缓存的用例,我强烈建议您尝试缓存金钱,它几乎自动:
def parent < ActiveRecord::Base
  has_many children
end

def child < ActiveRecord::Base
  index :parent_id
end

#now you can do the following without ever hitting the DB
parents = Parent.find :all
parents.each{ |p| p.children }

Cache Money的最大优势是,当您扩展到数据库复制滞后成为问题的时候,通过缓存写入可以保存您的屁股.这对于Rails尤其重要,其中复制滞后可以轻松导致500个错误,并且通常是您不想拥有的恶梦.

相关文章

前言设计一个缓存系统,不得不要考虑的问题就是:缓存穿透、...
在192.168.80.100要联网关闭防火墙及SElinuxsystemctlstopfi...
Redis与Memcache对比:1.Memcache是一个分布式的内存对象缓存...
安装Mencache:关闭防火墙及SElinuxsystemctl  stop  fi...
#安装php的yaf模块,参考https://www.cnblogs.com/shifu204/...
win10下安装配置apache、php、mysql、redis、memcache资源官...