3

我需要缓存(并过期)表中的所有模型。

例如,如果我有一个名为 Currency 的模型,我只有不到 10 种可能的货币。因此,最好有:

class Currency < ActiveRecord::Base
  cache_all(:expire_in => 10.minutes)
end

以便

Currency.all
Currency.find_by_name("USD")

不应该击中数据库。

你认为这可能是一个好方法吗?

此外,如果您认为使用没有数据库备份的模型会更好,请对此发表评论。请注意,我想要一个 AR 风格的关联。

4

1 回答 1

9

由于数据集如此之小,可能最好的办法是将其缓存在本地内存中。有几种方法可以做到这一点,一种是像我在这里展示的那样使用 Memoization。然而,这并不是最有效的,因为它会将all方法和find_by_name方法存储在单独的缓存中,即使它们是同一个对象。

另一种方法是重新定义手动缓存对象的方法。像这样的东西。

class Currency < ActiveRecord::Base
  def self.all
    @all_cache ||= super.map(&:freeze) # freeze so you don't modify the cached objects
  end

  def self.find_by_name(name)
    all.detect { |c| c.name.to_s.downcase == name.to_s.downcase }
  end

  def self.flush_all_cache
    @all_cache = nil
  end
end

可能有一个插件可以为您处理这个问题,但我根本没有研究过。

于 2009-08-03T16:18:35.687 回答