NAME
Jifty::DBI::Record::Memcached - records with caching behavior
SYNOPSIS
package Myrecord;
use base qw/Jifty::DBI::Record::Memcached/;
DESCRIPTION
This module subclasses the main Jifty::DBI::Record package to add a caching layer.
The public interface remains the same, except that records which have been loaded in the last few seconds may be reused by subsequent get or load methods without retrieving them from the database.
METHODS
load_from_hash
Overrides the implementation from Jifty::DBI::Record to add support for caching.
load_by_cols
Overrides the implementation from Jifty::DBI::Record to add support for caching.
_cache_config
You can override this method to change the duration of the caching from the default of 5 seconds.
For example, to cache records for up to 30 seconds, add the following method to your class:
sub _cache_config {
{ 'cache_for_sec' => 30 }
}
memcached_config
Returns a hash containing arguments to pass to Cache::Memcached during construction. The defaults are like:
(
services => [ '127.0.0.1:11211' ],
debug => 0,
)
You may want to override this method if you want a customized cache configuration:
sub memcached_config {
(
servers => [ '10.0.0.15:11211', '10.0.0.15:11212',
'10.0.0.17:11211', [ '10.0.0.17:11211', 3 ] ],
debug => 0,
compress_threshold => 10_000,
);
}
cache_key_prefix
Returns the prefix we should prepend to all cache keys. If you're using one memcached for multiple applications, you want this to be different for each application or they might end up mingling data.
AUTHOR
Matt Knopp <mhat@netlag.com>