lorenzo / redis
CakePHP support for the Redis key-value database
Installs: 146 468
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 2
Forks: 9
Open Issues: 1
Type:cakephp-plugin
pkg:composer/lorenzo/redis
Requires
- cakephp/database: 4.2.x
- cakephp/datasource: 4.2.x
Requires (Dev)
- cakephp/log: @stable
- phpunit/phpunit: @stable
- predis/predis: ^1.1
Suggests
- cakephp/log: Require this if you want to use the built-in command logger
This package is auto-updated.
Last update: 2025-10-25 17:07:45 UTC
README
This library makes it possible to create connections for any Redis database that can be created
and managed with CakePHP's ConnectionManager.
Redis is a great Key-Value database with excelent performance. It also offers several unique features for working with large lists, hashmaps and even pub-sub systems.
Connecting to the redis database
This library assumes that you either have installed phpredis or predis. We recommend installing phpredis
Configuring it in in your app.php file in
Just add any new named configuration under the Datasources key
'Datasources' => [ ... 'redis' => [ 'className' => 'Cake\Redis\RedisConnection', 'driver' => 'phpredis', // Can also use a full class name or 'predis' 'log' => false, // Log executed commands 'host' => '127.0.0.1', 'port' => 6379, 'timeout' => [optional], 'reconnectionDelay' => [optional], 'persistentId' => [optional], 'database' => [optional], 'options' => [], // extra options for the driver ] ]
Using ConnectionManager
You can also create new redis connections with the ConnectionManger
use Cake\Datasource\ConnectionManager; ConnectionManager::config('redis', [ 'className' => 'Cake\Redis\RedisConnection', 'driver' => 'Cake\Redis\Driver\PHPRedisDriver', 'log' => false, // Log executed commands 'host' => '127.0.0.1', 'port' => 6379, 'timeout' => [optional], 'reconnectionDelay' => [optional], 'persistentId' => [optional], 'database' => [optional], 'options' => [], // extra options for the driver ]);
Executing commands in Redis
You need to get a hold of the connection and the execute commands:
$redis = ConnectionManager::get('redis'); $redis->set('cakephp', 'awesome'); echo $redis->get('cakephp'); // Returns 'awesome'
Make sure you take a look at all the commands you can run in the PHPRedis Readme.
Executing a list of commands in a transaction
$redis = ConnectionManager::get('redis'); $redis->transactional(function ($client) { $client ->set('cakephp', 'awesome') ->set('another_key', 'value') });
The client instance the closure gets will buffer all the commands and execute them atomically at the end of the chain.
This method uses the multi() command internally.