0

Web サイトのパフォーマンスを高速化するためにフラグメント キャッシュを追加しようとしていました。今、developmentモードでテストしたので、これを変更します

#environments/developments.rb
config.action_controller.perform_caching = true

そして、erb

<% @projects.each do |project| %>
    <% cache project do %>
        <%= link_to "#{project.name}", category_project_path(@category, project) %>
        <br>
    <% end %>
<% end %>

しかし、うまくいかないようです。ページを更新するたびに、ターミナルにクエリが再び表示されました。

初めてクエリを実行するのは 1 回だけだと思っていましたか、それともキャッシュの概念を誤解していましたか?

Processing by CategoriesController#show as HTML
  Parameters: {"id"=>"3306"}
  Category Load (0.4ms)  SELECT  "categories".* FROM "categories" WHERE "categories"."id" = $1 LIMIT 1  [["id", 3306]]
  Project Load (0.5ms)  SELECT "projects".* FROM "projects" WHERE "projects"."category_id" IN (3306)
   (0.4ms)  SELECT DISTINCT COUNT(DISTINCT "projects"."id") FROM "projects" WHERE "projects"."category_id" = $1  [["category_id", 3306]]
  Project Load (1.0ms)  SELECT  DISTINCT "projects".* FROM "projects" WHERE "projects"."category_id" = $1 LIMIT 10 OFFSET 0  [["category_id", 3306]]
  Cache digest for app/views/categories/show.html.erb: 9b54e2d9c7ce230e3f6a333f00d549da
Read fragment views/projects/3670-20160715055333331671000/9b54e2d9c7ce230e3f6a333f00d549da (0.2ms)
  Cache digest for app/views/categories/show.html.erb: 9b54e2d9c7ce230e3f6a333f00d549da
Read fragment views/projects/3677-20160715055334439274000/9b54e2d9c7ce230e3f6a333f00d549da (0.2ms)
  Cache digest for app/views/categories/show.html.erb: 9b54e2d9c7ce230e3f6a333f00d549da
Read fragment views/projects/3678-20160715055334446172000/9b54e2d9c7ce230e3f6a333f00d549da (0.2ms)
  Cache digest for app/views/categories/show.html.erb: 9b54e2d9c7ce230e3f6a333f00d549da
Read fragment views/projects/3689-20160715055334536421000/9b54e2d9c7ce230e3f6a333f00d549da (0.1ms)
  Rendered categories/show.html.erb within layouts/application (8.7ms)
Completed 200 OK in 31ms (Views: 26.0ms | ActiveRecord: 2.3ms)
4

1 に答える 1

0

ログによると、製品はキャッシュから取り込まれ、製品に対してクエリは実行されないようです。

views/projects/3670-20160715055333331671000/9b54e2d9c7ce230e3f6a333f00d549da

真ん中の数字は product_id で、その後に製品レコードの updated_at 属性のタイムスタンプ値が続きます。Rails はタイムスタンプ値を使用して、古いデータを提供していないことを確認します。updated_at の値が変更された場合、新しいキーが生成されます (データベースへのクエリを起動します)。その後、Rails はそのキーに新しいキャッシュを書き込み、古いキーに書き込まれた古いキャッシュは二度と使用されません。この助けを願っています!

于 2016-07-15T07:07:07.497 に答える