garyr / memento
Lightweight cache library
Installs: 6 576
Dependents: 1
Suggesters: 0
Security: 0
Stars: 18
Watchers: 2
Forks: 5
Open Issues: 2
Requires
- php: >=5.3.3
- symfony/console: ~2.5 || ~2.6
Requires (Dev)
- phpunit/phpunit: 4.1.3
- predis/predis: v0.8.5
README
Memento
Thin php caching wrapper for file, memcache, or redis storage engines. Supports simple key => data object storage and invalidation, as well as group based methods. Note that group bases methods always expire at the same time and should only be used when invalidation operations need to happen simultaneously
Setup
$file = new Memento\Engine\File( array( 'path' => '/tmp/memento', // defaults to sys_get_temp_dir() . '/memento' ) ); // client instance (defaults to file based storage) $memento = new Memento\Client($file);
Memcache Setup
$memcache = new Memento\Engine\Memcache( array( 'host' => '127.0.0.1', 'port' => 11211 ) ); // client instance $memento = new Memento\Client($memcache);
Redis Setup
$redis = new Memento\Engine\Redis( array( 'host' => '127.0.0.1', 'port' => 6379 ) ); // client instance $memento = new Memento\Client($redis);
Store Example
// single key store request $memento->store(new Memento\Key('com.example.key'), array('mydata')); $groupKey = new Memento\Group\Key('com.example.group1'); // group key store request (multiple keys per group key) $memento->store( $groupKey, new Memento\Key('com.example.key1'), array('mydata') ); $memento->store( $groupKey, new Memento\Key('com.example.key2'), array('foo' => 'bar') );
Retrieve Example
// single key retrieve request $data = $memento->retrieve(new Memento\Key('com.example.key')); $groupKey = new Memento\Group\Key('com.example.group1'); // group key retrieve request $data = $memento->retrieve( $groupKey, new Memento\Key('com.example.key1') ); $data = $memento->retrieve( $groupKey, new Memento\Key('com.example.key2') );
Invalidate Example
// single key invalidate request $memento->invalidate(new Memento\Key('com.example')); // group key store request (invalidate a group in a single operation) $memento->invalidate(new Memento\Group\Key('com.example.group1'));
Sharding
For other than file based engines, sharding simply requires additional hosts. Sharding is accomplished based on the key supplied for the data and is pointed to a host (see Memento\Engine\EngineAbstract)
// redis sharding config example $redis = new Memento\Engine\Redis( array( array( 'host' => 'redis1.mydomain', 'port' => 6379 ), array( 'host' => 'redis2.mydomain', 'port' => 6379 ) ) ); // memcache sharding config example $memcache = new Memento\Engine\Memcache( array( array( 'host' => 'memcache1.mydomain', 'port' => 11211 ), array( 'host' => 'memcache2.mydomain', 'port' => 11211 ) ) );