GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages


Manual Reference Pages  -  CATALYST::PLUGIN::SESSION::STORE::FASTMMAP (3)

.ds Aq ’

NAME

Catalyst::Plugin::Session::Store::FastMmap - FastMmap session storage backend.

CONTENTS

SYNOPSIS



    use Catalyst qw/Session Session::Store::FastMmap Session::State::Foo/;

    MyApp->config(
        Plugin::Session => {
            expires => 3600,
            storage => /tmp/session
        },
    );

    # ... in an action:
    $c->session->{foo} = bar; # will be saved



DESCRIPTION

Catalyst::Plugin::Session::Store::FastMmap is a fast session storage plugin for Catalyst that uses an mmap’ed file to act as a shared memory interprocess cache. It is based on Cache::FastMmap.

    METHODS

get_session_data
store_session_data
delete_session_data
delete_expired_sessions These are implementations of the required methods for a store. See Catalyst::Plugin::Session::Store.
get_and_set_session_data This is the optional method for atomic write semantics. See Catalyst::Plugin::Session::AtomicWrite.
setup_session Sets up the session cache file.

CAVEATS

Very loaded sites with lots of data in the session hash may have old sessions expired prematurely, due to the LRU caching policy employed by Cache::FastMmap. To get around this you can increase the cache_size parameter, or switch session storage backends. Cache::FastMmap defaults to around 5mb (89 * 64k).

This is particularly inappropriate for use as a backend for e.g. Catalyst::Plugin::Session::PerUser, for example.

As Cache::FastMmap is not thread-safe (at least version 1.30 and before) therefore also this module does not work in multi-threaded environment. It is fork-safe, however keep in mind that on Win32 the perl fork call is implemented as an emulation via threads - that is the reason why you cannot use this store for example when running you catalyst application on Win32 platform with Catalyst::Engine::HTTP::Prefork engine.

CONFIGURATION

These parameters are placed in the hash under the Plugin::Session key in the configuration hash.
storage Specifies the file to be used for the sharing of session data. The default value will use File::Spec to find the default tempdir, and use a file named MyApp_session_data, where MyApp is replaced with the appname.

Note that the file will be created with mode 0640, which means that it will only be writeable by processes running with the same uid as the process that creates the file. If this may be a problem, for example if you may try to debug the program as one user and run it as another, specify a filename like /tmp/session-$>, which includes the UID of the process in the filename.

init_file
cache_size
unlink_on_exit See the Cache::FastMmap documentation for the meaning of these keys. If these keys are not present Cache::FastMmap’s defaults will be used.

SEE ALSO

Catalyst, Catalyst::Plugin::Session, Cache::FastMmap.

AUTHORS

This module is derived from Catalyst::Plugin::Session::FastMmap code, and has been heavily modified since.



  Andrew Ford
  Andy Grundman
  Christian Hansen
  Yuval Kogman, <nothingmuch@woobling.org>
  Marcus Ramberg
  Sebastian Riedel
  Tomas Doran, (t0m) <bobtfish@bobtfish.net>



COPYRIGHT

Copyright (c) 2005 - 2012 the Catalyst::Plugin::Session::Store::FastMmap AUTHORS as listed above.

LICENSE

This program is free software, you can redistribute it and/or modify it under the same terms as Perl itself.
Search for    or go to Top of page |  Section 3 |  Main Index


perl v5.20.3 CATALYST::PLUGIN::SESSION::STORE::FASTMMAP (3) 2012-01-31

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with manServer 1.07.