Module: ActionController::Caching

Extended by:
ActiveSupport::Autoload, ActiveSupport::Concern
Includes:
Actions, ConfigMethods, Fragments, Pages, Sweeping
Defined in:
actionpack/lib/action_controller/caching.rb,
actionpack/lib/action_controller/caching/pages.rb,
actionpack/lib/action_controller/caching/actions.rb,
actionpack/lib/action_controller/caching/sweeping.rb,
actionpack/lib/action_controller/caching/fragments.rb

Overview

Caching is a cheap way of speeding up slow applications by keeping the result of calculations, renderings, and database calls around for subsequent requests. Action Controller affords you three approaches in varying levels of granularity: Page, Action, Fragment.

You can read more about each approach and the sweeping assistance by clicking the modules below.

Note: To turn off all caching and sweeping, set

config.action_controller.perform_caching = false.

Caching stores

All the caching stores from ActiveSupport::Cache are available to be used as backends for Action Controller caching. This setting only affects action and fragment caching as page caching is always written to disk.

Configuration examples (MemoryStore is the default):

config.action_controller.cache_store = :memory_store
config.action_controller.cache_store = :file_store, "/path/to/cache/directory"
config.action_controller.cache_store = :drb_store, "druby://localhost:9192"
config.action_controller.cache_store = :mem_cache_store, "localhost"
config.action_controller.cache_store = :mem_cache_store, Memcached::Rails.new("localhost:11211")
config.action_controller.cache_store = MyOwnStore.new("parameter")

Defined Under Namespace

Modules: Actions, ConfigMethods, Fragments, Pages, Sweeping Classes: Sweeper

Instance Method Summary collapse

Methods included from ActiveSupport::Autoload

autoload, autoload_at, autoload_under, autoloads, eager_autoload, eager_autoload!

Methods included from ActiveSupport::Concern

append_features, extended, included

Methods included from Pages

#cache_page, #expire_page

Methods included from Actions

#_save_fragment

Methods included from Fragments

#expire_fragment, #fragment_cache_key, #fragment_exist?, #instrument_fragment_cache, #read_fragment, #write_fragment

Methods included from ConfigMethods

#cache_store, #cache_store=

Instance Method Details

#caching_allowed?Boolean

Returns:

  • (Boolean)


70
71
72
# File 'actionpack/lib/action_controller/caching.rb', line 70

def caching_allowed?
  request.get? && response.status == 200
end