首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Rails jbuilder缓存+查询

Rails jbuilder缓存+查询
EN

Stack Overflow用户
提问于 2014-01-10 06:41:58
回答 1查看 2.4K关注 0票数 1

在我对如何缓存jbuilder视图和activerecord查询提出一些建议之后。我现在这样做感觉并不正确,因为我基本上在缓存中存储了两个东西。我能以某种方式将其组合起来吗?我需要缓存SQL记录,这样数据库就不会命中,视图文件也需要最大限度地提高速度。

代码语言:javascript
复制
# Controller
@posts = Rails.cache.fetch ["posts"], :expires_in => 1.hour do
  Post.all.limit(10).order("id desc").to_a
end

代码语言:javascript
复制
# Jbuilder view
json.cache! ["posts"], :expires_in => 1.hour do |json|
    json.array! @posts do |post|
      json.id post.id
      json.title post.title
    end
 end
EN

回答 1

Stack Overflow用户

发布于 2014-05-21 20:38:27

我认为你想得太多了,除非activerecord查询真的很慢。缓存机制非常智能,它会拉出你的对象来检查updated_at。如果更新,则构建json响应。如果没有,则为先前构建的版本提供服务。通常,这会将2秒的作业时间缩短到10ms,或者缩短到初始数据库查询所需的时间。

但是,如果你坚持的话,这个答案可以告诉你一种方法。https://stackoverflow.com/a/23783119/252799注意到activerecord调用在缓存块中,因此只有在缓存未命中的情况下才会执行。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21032741

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档