mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
Caching guide: documents that page/action caching run in an after_filter, and this spurious cache entries are avoided just by halting the request
This commit is contained in:
parent
326829633c
commit
acde75c84a
1 changed files with 4 additions and 0 deletions
|
@ -67,6 +67,8 @@ If you want a more complicated expiration scheme, you can use cache sweepers to
|
|||
|
||||
Note: Page caching ignores all parameters. For example +/products?page=1+ will be written out to the filesystem as +products.html+ with no reference to the +page+ parameter. Thus, if someone requests +/products?page=2+ later, they will get the cached first page. Be careful when page caching GET parameters in the URL!
|
||||
|
||||
INFO: Page caching runs in an after filter. Thus, invalid requests won't generate spurious cache entries as long as you halt them. Tipically, a redirection in some before filter that checks request preconditions does the job.
|
||||
|
||||
h4. Action Caching
|
||||
|
||||
One of the issues with Page Caching is that you cannot use it for pages that require to restrict access somehow. This is where Action Caching comes in. Action Caching works like Page Caching except for the fact that the incoming web request does go from the webserver to the Rails stack and Action Pack so that before filters can be run on it before the cache is served. This allows authentication and other restriction to be run while still serving the result of the output from a cached copy.
|
||||
|
@ -98,6 +100,8 @@ You can modify the default action cache path by passing a +:cache_path+ option.
|
|||
|
||||
Finally, if you are using memcached, you can also pass +:expires_in+. In fact, all parameters not used by +caches_action+ are sent to the underlying cache store.
|
||||
|
||||
INFO: Action caching runs in an after filter. Thus, invalid requests won't generate spurious cache entries as long as you halt them. Tipically, a redirection in some before filter that checks request preconditions does the job.
|
||||
|
||||
h4. Fragment Caching
|
||||
|
||||
Life would be perfect if we could get away with caching the entire contents of a page or action and serving it out to the world. Unfortunately, dynamic web applications usually build pages with a variety of components not all of which have the same caching characteristics. In order to address such a dynamically created page where different parts of the page need to be cached and expired differently Rails provides a mechanism called Fragment Caching.
|
||||
|
|
Loading…
Reference in a new issue