为什么这个缓存语句没有写出我期望的密钥?

mar*_*ion 5 caching ruby-on-rails russian-doll-caching ruby-on-rails-5

我有_profile.html.erb部分内容:

<% cache [current_user.roles.first, profile, @selected_profile, params[:rating]] do %>
Run Code Online (Sandbox Code Playgroud)

然而,这是我在服务器日志中看到的:

Read fragment views/profiles/26-20161212033839290582/profiles/52-20161213010040474070/profiles/14-20161213015458288839/profiles/34-20161212035644491093/profiles/33-20161212035644237925/profiles/38-20161207092843851446/profiles/35-20161212040016291016/profiles/36-20161212040016565707/profiles/4-20161213021028862933/profiles/39-20161207092843925084/profiles/46-20161207092844067579/profiles/47-20161207223703646028/profiles/37-20161212040016656625/660bdc6ad0b20e4c5329112cf79946f7 (0.1ms)
Run Code Online (Sandbox Code Playgroud)

我什么roles也没看到.

发生的事情是,如果我以具有admin角色的用户身份登录,然后以具有其他角色的用户身份登录,我看到profiles显示的缓存就像我是管理员而不是具有正确视图的其他用户.

可能导致这种情况的原因以及如何解决?

编辑1

如果我将cache语句更改为:

<% cache [current_user, profile, @selected_profile, params[:rating]] do %>
Run Code Online (Sandbox Code Playgroud)

并刷新,这是日志的样子:

Write fragment views/users/2-20161218005548388099/profiles/37-20161212040016656625///bb163edd4a8c7af2db71a04243338e7b (0.1ms)
  Rendered collection of profiles/_profile.html.erb [1 times] (25.4ms)
Write fragment views/profiles/26-20161212033839290582/profiles/52-20161213010040474070/profiles/14-20161213015458288839/profiles/34-20161212035644491093/profiles/33-20161212035644237925/profiles/38-20161207092843851446/profiles/35-20161212040016291016/profiles/36-20161212040016565707/profiles/4-20161213021028862933/profiles/39-20161207092843925084/profiles/46-20161207092844067579/profiles/47-20161207223703646028/profiles/37-20161212040016656625/83ddeaa031bf68e602ce66af2d268317 (0.1ms)
Run Code Online (Sandbox Code Playgroud)

编辑2

当我binding.pry进入时_profile.html.erb,我得到以下内容:

[3] pry(#<#<Class:0x007f968480ec98>>)> current_user.roles.first
=> #<Role:0x007f969e4422a8 id: 1, name: "admin", resource_id: nil, resource_type: nil, created_at: Mon, 12 Sep 2016 00:38:47 UTC +00:00, updated_at: Mon, 12 Sep 2016 00:38:47 UTC +00:00>
Run Code Online (Sandbox Code Playgroud)

我甚至尝试了以下方法:

<% cache [current_user.roles.first.name, profile, @selected_profile, params[:rating]] do %>
Run Code Online (Sandbox Code Playgroud)

当以管理员用户身份登录为非管理员用户时,它仍然给我相同的缓存结果.

编辑3

这是cache调用调用集合的块_profile.html.erb:

  <% cache @profiles do %>
    <div class="wrapper wrapper-content">
    <% @profiles.to_a.in_groups_of(3, false).each do |profiles| %>
        <div class="row">
            <%= render partial: "profile", collection: profiles %>
        </div>
    <% end %>
    </div>
  <% end %>
Run Code Online (Sandbox Code Playgroud)

Bla*_*son 2

您的父缓存正在阻止子缓存正确完成其工作。您可以删除父缓存,或者将其移至顶部,然后每个子缓存都可以分开

用。。。来代替<% cache @profiles do %>

<% cache [current_user.roles.first.try(:name), @profiles, @selected_profile, params[:rating]] do %>
Run Code Online (Sandbox Code Playgroud)

然后是内部_profile.html.erb

<% cache [current_user.roles.first.try(:name), profile, @selected_profile, params[:rating]] do %>
Run Code Online (Sandbox Code Playgroud)