NAME

Dancer::Plugin::MemcachedFast - Cache things using Cache::Memcached::Fast

SYNOPSIS

This plugin allows Dancer to use Cache::Memcached::Fast to get and store content on a number of memcached servers.

Add the following to your configuration file to enable the plugin:

plugins:
    MemcachedFast:
        servers:
            - "127.0.0.1:11211"
            - "127.0.0.1:22122"
        default_timeout: 3600
        namespace: "myapp:"

The options that can be used are the same as the parameters to the new constructor of Cache::Memcached::Fast, apart from default_timeout.

The default_timeout parameter defaults to 3600 seconds. It allows you to specify a time, in seconds, after which you would like keys to expire from the cache.

It accepts the same options that Cache::Memcached::Fast accepts.

In your app:

package MyApp;
use Dancer;
use Dancer::Plugin::MemcachedFast;

# Simply fetch the index from memcached if found,
# or set the cache to the parsed index template
get '/' => sub {
    memcached_get_or_set('index', sub {
        template 'index';
    });
};

# The login page can be shown from the cache,
# whereas if a user is logged in the cache is
# user-specific
get '/admin' => sub {
    unless (session->{username}) {
        return memcached_get_or_set('admin_login', sub {
            template 'admin_login';
        });
    };
    memcached_get_or_set('admin-home-' . session->{username}, sub {
        template 'admin_home';
    });
};

# Use memcache to cache bits of information only,
# for a specific amount of seconds
get '/articles' => sub {
    my $articles = memcached_get_or_set('articles-list', sub {
        # use DBI to fetch last 10 articles
        my @last_10_articles = ...;
        return \@last_10_articles
    }, 300);
    template 'articles_list' => { articles => $articles };
};

# forcibly delete a number of keys from the cache
get '/admin/PANIC' => {
    return redirect '/admin'
        unless session->{username};
    memcached_delete(
        qw/articles_list admin_login/,
        'admin-home-' . session->{username},
    );
    redirect '/admin';
};

# set a cache to a specified value unconditionally
get '/admin/meaningoflife' => sub {
    return redirect '/admin'
        unless session->{username};
    memcached_set('meaning', 42);
    redirect '/admin';
};

# get a value from the cache, who cares if it isn't there?!
get '/admin/maybe' => sub {
    my $meaning = memcached_get('meaningoflife');
    template 'meaning' => { meaning => $meaning };
};

TIMEOUTS

You can set the default timeout via the configuration, as explained in the SYNOPSIS section. The default is 3600 seconds.

If you want to cache a value for as long as there is memory available to Memcache, you can achieve that by passing 0 as the expiration parameter (not undef, as that just uses the default_timeout).

KEYWORDS

memcached_get_or_set

Will check whether the specified key is found in the cache and return it where available. Otherwise it will set it to either the value given, or will call the coderef given ans set it to the value returned by the coderef. It will be cached either for the default number of seconds, or the number of seconds given.

# returns the value on memcached for 'keyname' if found, or
# sets the 'keyname' to the value 42 and its expiration to 300 seconds
memcached_get_or_set('key name', sub { 42 }, 300);
memcached_get_or_set('key name', 42, 300);
memcached_get_or_set('key name', [42], 300);

memcached_get

Attempts to get a value from memcached, and returns it. Uses get_multi if given more than one value to get. Expands arrayrefs where needed.

my $maybe  = memcached_get('key');
my $values = memcached_get(qw/keya keyb keyc/);
$values = memcached_get([qw/keya keyb keyc/], 'keyd', ['keye','keyf']);

memcached_gets

Retries the value and its CAS for the key given. Uses gets_multi if given more than one value to get. Expands arrayrefs where needed.

memcached_set

Sets unconditionally a key to a given value. A coderef may be used also, and its return value will be used. Alternatively, provide an arrayref for it to use set_multi on it. Takes an optional third value indicating the number of seconds the key will be cached for, or the default number of seconds. You can use an expiration value of 0 to mean that the value should never expire from the cache.

memcached_set('meaningoflife', 42);
memcached_set('meaningoflife', sub { 21 * 2 });
# "meaningoflife" will be cached for the default number of seconds:
memcached_set(['meaningoflife',42],['test',1234,300]);
memcached_set(['test',sub{42},123],['abc','def']);

memcached_add

Similar to memcached_set, but only operates if the key is not already stored in memcached.

memcached_replace

Similar to memcached_set, but only operates if the key is already stored in memcached.

memcached_delete

Forcibly expunges one or more keys from the cache.

memcached_delete('meaningoflife');
memcached_delete('meaningoflife','test');
memcached_delete( [ 'abc', 'def' ], [ 'xyz' ] );
memcached_delete( [ 'abc', 'def' ], 'xyz' );

memcached_append

Appends the given string to the already stored scalar value. See Cache::Memcached::Fast's method append and append_multi. append is used if the two given parameters are scalars, append_multi will be used if they are arrayrefs.

memcached_set( 'meaningoflife', '4' );
memcached_append( 'meaningoflife', '2' );
my $fourtytwo = memcached_get('meaningoflife');
memcached_append(['meaningoflife',42],['answer','whoknows']);

memcached_prepend

Same as append_multi, but works at the beginning of the string.

memcached_incr

Increments the key given by 1 or the optional value given. Can operate on arrayrefs, using incr_multi.

memcached_decr

Same as memcached_incr but decrements.

memcached_flush_all

Invalidates all caches the client knows about. See Cache::Memcached::Fast's flush_all method.

memcached_nowait_push

Pushes all the pending request to the server(s), see Cache::Memcached::Fast's nowait_push method.

memcached_server_versions

Returns the versions of the servers the plugin is connected to.

memcached_disconnect_all

Just in case your program forks and needs to disconnect them

memcached_compress

Needs a boolean, to enable or disable the compression. In order to work, the configuration options compress_threshold and compress_methods need to be pgiven. See Cache::Memcached::Fast for the options.

memcached_compress(42); # true, starts compressing
memcached_compress(1);  # true, starts compressing
memcached_compress(''); # false, stops compressing
memcached_compress(0);  # false, stops compressing

memcached_namespace

Either returns the current namespace prefix, or sets it to the given value and returns the old value.

my $current_prefix = memcached_namespace;
my $old_prexix     = memcached_namespace('test:');
# $current_prefix eq $old_prefix
$current_prefix = memcached_namespace;
# $current_prefix eq 'test:'