rtomayko/rack-cache
{ "createdAt": "2008-10-25T02:02:09Z", "defaultBranch": "master", "description": "Real HTTP Caching for Ruby Web Apps", "fullName": "rtomayko/rack-cache", "homepage": "http://rtomayko.github.io/rack-cache/", "language": "Ruby", "name": "rack-cache", "pushedAt": "2022-03-04T03:57:50Z", "stargazersCount": 826, "topics": [], "updatedAt": "2025-10-27T11:18:45Z", "url": "https://github.com/rtomayko/rack-cache"}Moved to https://github.com/rack/rack-cache
Section titled “Moved to https://github.com/rack/rack-cache”Rack::Cache
Section titled “Rack::Cache”Rack::Cache is suitable as a quick drop-in component to enable HTTP caching for Rack-based applications that produce freshness (Expires, Cache-Control) and/or validation (Last-Modified, ETag) information:
- Standards-based (RFC 2616)
- Freshness/expiration based caching
- Validation (If-Modified-Since / If-None-Match)
- Vary support
- Cache-Control: public, private, max-age, s-maxage, must-revalidate, and proxy-revalidate.
- Portable: 100% Ruby / works with any Rack-enabled framework
- Disk, memcached, and heap memory storage backends
For more information about Rack::Cache features and usage, see:
https://rtomayko.github.com/rack-cache/
Rack::Cache is not overly optimized for performance. The main goal of the project is to provide a portable, easy-to-configure, and standards-based caching solution for small to medium sized deployments. More sophisticated / high-performance caching systems (e.g., Varnish, Squid, httpd/mod-cache) may be more appropriate for large deployments with significant throughput requirements.
Installation
Section titled “Installation”gem install rack-cacheBasic Usage
Section titled “Basic Usage”Rack::Cache is implemented as a piece of Rack middleware and can be used with
any Rack-based application. If your application includes a rackup (.ru) file
or uses Rack::Builder to construct the application pipeline, simply require
and use as follows:
require 'rack/cache'
use Rack::Cache, metastore: 'file:/var/cache/rack/meta', entitystore: 'file:/var/cache/rack/body', verbose: true
run appAssuming you’ve designed your backend application to take advantage of HTTP’s caching features, no further code or configuration is required for basic caching.
Using with Rails
Section titled “Using with Rails”config.action_dispatch.rack_cache = true# orconfig.action_dispatch.rack_cache = { verbose: true, metastore: 'file:/var/cache/rack/meta', entitystore: 'file:/var/cache/rack/body'}You should now see Rack::Cache listed in the middleware pipeline:
rake middlewareUsing with Dalli
Section titled “Using with Dalli”Dalli is a high performance memcached client for Ruby. More information at: https://github.com/mperham/dalli
require 'dalli'require 'rack/cache'
use Rack::Cache, verbose: true, metastore: "memcached://localhost:11211/meta", entitystore: "memcached://localhost:11211/body"
run appNoop entity store
Section titled “Noop entity store”Does not persist response bodies (no disk/memory used).
Responses from the cache will have an empty body.
Clients must ignore these empty cached response (check for X-Rack-Cache response header).
Atm cannot handle streamed responses, patch needed.
require 'rack/cache'
use Rack::Cache, verbose: true, metastore: <any backend> entitystore: "noop:/"
run appIgnoring tracking parameters in cache keys
Section titled “Ignoring tracking parameters in cache keys”It’s fairly common to include tracking parameters which don’t affect the content
of the page. Since Rack::Cache uses the full URL as part of the cache key, this
can cause unneeded churn in your cache. If you’re using the default key class
Rack::Cache::Key, you can configure a proc to ignore certain keys/values like
so:
Rack::Cache::Key.query_string_ignore = proc { |k, v| k =~ /^(trk|utm)_/ }