微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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个错误,并且通常是您不想拥有的恶梦.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐