Package Data | |
---|---|
Maintainer Username: | windevalley |
Maintainer Contact: | tom.castleman@b3-it.com (Tom Castleman) |
Package Create Date: | 2015-10-14 |
Package Last Update: | 2015-10-14 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2025-01-18 03:06:57 |
Package Statistics | |
---|---|
Total Downloads: | 12 |
Monthly Downloads: | 0 |
Daily Downloads: | 0 |
Total Stars: | 2 |
Total Watchers: | 2 |
Total Forks: | 0 |
Total Open Issues: | 0 |
Integrating with cloud memcached services such as MemCachier and memcached cloud can require memcached features not available with the built-in Laravel 5 Cache memcached driver.
These include:
Adding 3 new configuration items, this package enhances the built-in Laravel 5 Cache memcached driver. Optionally, this package also allows these extra configuration items to be used for memcached Sessions.
Read on for detailed instructions - you may find it useful to reference the demo app at the same time.
Update: see here for details on the PRs I submitted to laravel/framework.
= PHP 5.4 with ext-memcached
Available to install as a Composer package on Packagist, all you need to do is:
composer require b3it/laravel-memcached-plus
If your local environment does not meet the requirements you may need to append the
ignore-platform-reqs
option:
composer require b3it/laravel-memcached-plus --ignore-platform-reqs
Once installed you can use this package to enhance the Laravel Cache and Session services.
This section discusses the Laravel application configuration file app/config.php
.
In the providers
array you need to replace following built-in Service Providers:
Illuminate\Cache\CacheServiceProvider
and (optionally)Illuminate\Session\SessionServiceProvider
A recommended approach is to comment out the built-in providers and append the Service Providers from this package:
'providers' => [
...
//'Illuminate\Cache\CacheServiceProvider',
...
//'Illuminate\Session\SessionServiceProvider',
...
/*
* Application Service Providers...
*/
...
'B3IT\MemcachedPlus\CacheServiceProvider',
'B3IT\MemcachedPlus\SessionServiceProvider',
],
On a fresh install of Laravel 5.0.13 the providers array is on line 111 of app/config.php
.
The B3IT\MemcachedPlus\SessionServiceProvider
is optional. You only need to add this if:
This section discusses the Laravel cache configuration file config/cache.php
.
This package makes the following extra configuration items are available for use with a memcached store:
persistent_id
- [Memcached::__construct
] (http://php.net/manual/en/memcached.construct.php)
explains how this is usedsasl
- used by Memcached::setSaslAuthData
options
- see Memcached::setOptions
These may be used in a store config like so:
'stores' => [
'memcachedstorefoo' => [
'driver' => 'memcached',
'persistent_id' => 'laravel',
'sasl' => [
env('MEMCACHIER_USERNAME'),
env('MEMCACHIER_PASSWORD')
],
'options' => [
'OPT_NO_BLOCK' => true,
'OPT_AUTO_EJECT_HOSTS' => true,
'OPT_CONNECT_TIMEOUT' => 2000,
'OPT_POLL_TIMEOUT' => 2000,
'OPT_RETRY_TIMEOUT' => 2,
],
'servers' => [
[
'host' => '127.0.0.1', 'port' => 11211, 'weight' => 100
],
],
],
],
When defining options
you should set the config key to the Memcached
constant name as a string.
This avoids any issues with local environments missing ext-memcached and throwing a warning about
undefined constants. The config keys are automatically resolved into Memcached
constants by the
MemcachedPlus\MemcachedConnector
which throws a RuntimeException
if the constant is invalid.
Note that as this package enhances the built-in Laravel 5 memcached Cache driver the driver string
remains memcached
.
In case you are unfamiliar with how to use multiple cache stores in Laravel, you would access this store from your application code like so:
$value = Cache::store('memcachedstorefoo')->get('key');
This section discusses the Laravel session configuration file config/session.php
.
If you are using memcached sessions you will have set the driver
configuration item to 'memcached'.
If you have added the B3IT\MemcachedPlus\SessionServiceProvider
as discussed above, the
memcached_store
configuration item is available. This is explained in the following new snippet
you can paste into your session configuration file:
/*
|--------------------------------------------------------------------------
| Session Cache Store
|--------------------------------------------------------------------------
|
| When using the "memcached" session driver, you may specify a cache store
| that should be used for these sessions. This should correspond to a
| store in your cache configuration options which uses the memcached
| driver.
|
*/
'memcached_store' => 'memcachier',
I created a demo app for you to see how this package integrates with Laravel 5 and how you could run it on Heroku.
I submitted 2 PRs to laravel/framework to integrate this package in to the framework itself:
However @taylorotwell closed them due to lack of tests. When time permits I'm planning to add tests and re-submit, but in the meantime if anyone wishes to contribute them please submit a PR.
Please do let me know if you have any comments or queries.
Thanks!