Configuration
Rack::Cache includes a configuration system that can be used to specify fairly sophisticated cache policy on a global or per-request basis.
Setting Cache Options
Cache options can be set when the Rack::Cache object is created,
or by setting a rack-cache.<option> variable in Rack’s
Environment.
When the Rack::Cache object is instantiated:
use Rack::Cache,
:verbose => true,
:metastore => 'memcached://localhost:11211/',
:entitystore => 'file:/var/cache/rack'
Using Rack’s Environment:
env.merge!(
'rack-cache.verbose' => true,
'rack-cache.metastore' => 'memcached://localhost:11211/',
'rack-cache.entitystore' => 'file:/var/cache/rack'
)
Cache Option Reference
Use the following options to customize Rack::Cache:
verbose
Boolean specifying whether verbose trace logging is enabled. This option is
currently enabled (true) by default but is likely to be disabled (false) in
a future release. All log output is written to the rack.errors stream, which
is typically set to STDERR.
The trace, info, warn, and error methods can be used within the
configuration context to write messages to the errors stream.
default_ttl
An integer specifying the number of seconds a cached object should be considered
“fresh” when no explicit freshness information is provided in a response.
Explicit Cache-Control or Expires response headers always override this
value. The default_ttl option defaults to 0, meaning responses without
explicit freshness information are considered immediately “stale” and will not
be served from cache without validation.
metastore
A URI specifying the MetaStore implementation used to store request/response meta information. See the Rack::Cache Storage Documentation for detailed information on different storage implementations.
If no metastore is specified, the heap:/ store is assumed. This implementation
has significant draw-backs so explicit configuration is recommended.
entitystore
A URI specifying the EntityStore implementation used to store response bodies. See the Rack::Cache Storage Documentation for detailed information on different storage implementations.
If no entitystore is specified, the heap:/ store is assumed. This
implementation has significant draw-backs so explicit configuration is
recommended.
private_headers
An array of request header names that cause the response to be treated with
private cache control semantics. The default value is ['Authorization', 'Cookie'].
If any of these headers are present in the request, the response is considered
private and will not be cached unless the response is explicitly marked public
(e.g., Cache-Control: public).
allow_reload
A boolean specifying whether reload requests sent by the client should be
honored by the cache. When this option is enabled (rack-cache.allow_reload
is true), requests that include a Cache-Control: no-cache header cause
the cache to discard anything it has stored for the request and ask that the
response be fully generated.
Most browsers include a Cache-Control: no-cache header when the user performs
a “hard refresh” (e.g., holding Shift while clicking the “Refresh” button).
IMPORTANT: Enabling this option globally allows all clients to break your cache.
allow_revalidate
A boolean specifying whether revalidate requests sent by the client should be
honored by the cache. When this option is enabled (rack-cache.allow_revalidate
is true), requests that include a Cache-Control: max-age=0 header cause the
cache to assume its copy of the response is stale, resulting in a conditional
GET / validation request to be sent to the server.
Most browsers include a Cache-Control: max-age=0 header when the user performs
a refresh (e.g., clicking the “Refresh” button).
IMPORTANT: Enabling this option globally allows all clients to break your cache.
cache_key
TODO: Document custom cache keys