Class RedisEngine
Redis storage engine for cache.
Property Summary
- 
        $_Redis protectedRedisRedis wrapper. 
- 
        $_config protectedarrayRuntime config 
- 
        $_configInitialized protectedboolWhether the config property has already been configured with defaults 
- 
        $_defaultConfig protectedarrayThe default config used unless overridden by runtime configuration 
- 
        $_groupPrefix protectedstringContains the compiled string with all groups prefixes to be prepended to every key in this cache engine 
Method Summary
- 
          __destruct() publicDisconnects from the redis server 
- 
          _configDelete() protectedDeletes a single config key. 
- 
          _configRead() protectedReads a config key. 
- 
          _configWrite() protectedWrites a config key. 
- 
          _connect() protectedConnects to a Redis server 
- 
          _key() protectedGenerates a safe key, taking account of the configured key prefix 
- 
          add() publicWrite data for key into cache if it doesn't exist already. If it already exists, it fails and returns false. 
- 
          clear() publicDelete all keys from the cache 
- 
          clearGroup() publicIncrements the group value to simulate deletion of all keys under a group old values will remain in storage until they expire. 
- 
          config() public deprecatedGets/Sets the config. 
- 
          configShallow() publicMerge provided config with existing config. Unlike config()which does a recursive merge for nested keys, this method does a simple merge.
- 
          decrement() publicDecrements the value of an integer cached key & update the expiry time 
- 
          delete() publicDelete a key from the cache 
- 
          deleteMany() publicDeletes keys from the cache 
- 
          gc() publicGarbage collection 
- 
          getConfig() publicReturns the config. 
- 
          groups() publicReturns the group valuefor each of the configured groups If the group initial value was not found, then it initializes the group accordingly.
- 
          increment() publicIncrements the value of an integer cached key & update the expiry time 
- 
          init() publicInitialize the Cache Engine 
- 
          key() publicGenerates a safe key for use with cache engine storage engines. 
- 
          read() publicRead a key from the cache 
- 
          readMany() publicRead multiple keys from the cache 
- 
          setConfig() publicSets the config. 
- 
          warning() protectedCache Engines may trigger warnings if they encounter failures during operation, if option warnOnWriteFailures is set to true. 
- 
          write() publicWrite data for key into cache. 
- 
          writeMany() publicWrite data for many keys into cache 
Method Detail
_configDelete() ¶ protected
_configDelete(string $key): voidDeletes a single config key.
Parameters
- 
                string$key
- Key to delete. 
Returns
voidThrows
Cake\Core\Exception\Exceptionif attempting to clobber existing config
_configRead() ¶ protected
_configRead(string|null $key): mixedReads a config key.
Parameters
- 
                string|null$key
- Key to read. 
Returns
mixed_configWrite() ¶ protected
_configWrite(string|array $key, mixed $value, bool|string $merge = false): voidWrites a config key.
Parameters
- 
                string|array$key
- Key to write to. 
- 
                mixed$value
- Value to write. 
- 
                bool|string$merge optional
- True to merge recursively, 'shallow' for simple merge, false to overwrite, defaults to false. 
Returns
voidThrows
Cake\Core\Exception\Exceptionif attempting to clobber existing config
_key() ¶ protected
_key(string $key): stringGenerates a safe key, taking account of the configured key prefix
Parameters
- 
                string$key
- the key passed over 
Returns
stringThrows
InvalidArgumentExceptionIf key's value is empty
add() ¶ public
add(string $key, mixed $value): boolWrite data for key into cache if it doesn't exist already. If it already exists, it fails and returns false.
Defaults to a non-atomic implementation. Subclasses should prefer atomic implementations.
Parameters
- 
                string$key
- Identifier for the data. 
- 
                mixed$value
- Data to be cached. 
Returns
boolLinks
clear() ¶ public
clear(bool $check): boolDelete all keys from the cache
Parameters
- 
                bool$check
- If true will check expiration, otherwise delete all. 
Returns
boolclearGroup() ¶ public
clearGroup(string $group): boolIncrements the group value to simulate deletion of all keys under a group old values will remain in storage until they expire.
Parameters
- 
                string$group
- name of the group to be cleared 
Returns
boolconfig() ¶ public
config(string|array|null $key = null, mixed|null $value = null, bool $merge = true): mixedGets/Sets the config.
Usage
Reading the whole config:
$this->config();Reading a specific value:
$this->config('key');Reading a nested value:
$this->config('some.nested.key');Setting a specific value:
$this->config('key', $value);Setting a nested value:
$this->config('some.nested.key', $value);Updating multiple config settings at the same time:
$this->config(['one' => 'value', 'another' => 'value']);Parameters
- 
                string|array|null$key optional
- The key to get/set, or a complete array of configs. 
- 
                mixed|null$value optional
- The value to set. 
- 
                bool$merge optional
- Whether to recursively merge or overwrite existing config, defaults to true. 
Returns
mixedThrows
Cake\Core\Exception\ExceptionWhen trying to set a key that is invalid.
configShallow() ¶ public
configShallow(string|array $key, mixed|null $value = null): $thisMerge provided config with existing config. Unlike config() which does
a recursive merge for nested keys, this method does a simple merge.
Setting a specific value:
$this->configShallow('key', $value);Setting a nested value:
$this->configShallow('some.nested.key', $value);Updating multiple config settings at the same time:
$this->configShallow(['one' => 'value', 'another' => 'value']);Parameters
- 
                string|array$key
- The key to set, or a complete array of configs. 
- 
                mixed|null$value optional
- The value to set. 
Returns
$thisdecrement() ¶ public
decrement(string $key, int $offset = 1): int|falseDecrements the value of an integer cached key & update the expiry time
Parameters
- 
                string$key
- Identifier for the data 
- 
                int$offset optional
- How much to subtract 
Returns
int|falsedelete() ¶ public
delete(string $key): boolDelete a key from the cache
Parameters
- 
                string$key
- Identifier for the data 
Returns
booldeleteMany() ¶ public
deleteMany(array $keys): arrayDeletes keys from the cache
Parameters
- 
                array$keys
- An array of identifiers for the data 
Returns
arraygc() ¶ public
gc(int|null $expires = null): voidGarbage collection
Permanently remove all expired and deleted data
Parameters
- 
                int|null$expires optional
- [optional] An expires timestamp, invalidating all data before. 
Returns
voidgetConfig() ¶ public
getConfig(string|null $key = null, mixed $default = null): mixedReturns the config.
Usage
Reading the whole config:
$this->getConfig();Reading a specific value:
$this->getConfig('key');Reading a nested value:
$this->getConfig('some.nested.key');Reading with default value:
$this->getConfig('some-key', 'default-value');Parameters
- 
                string|null$key optional
- The key to get or null for the whole config. 
- 
                mixed$default optional
- The return value when the key does not exist. 
Returns
mixedgroups() ¶ public
groups(): string[]Returns the group value for each of the configured groups
If the group initial value was not found, then it initializes
the group accordingly.
Returns
string[]increment() ¶ public
increment(string $key, int $offset = 1): int|falseIncrements the value of an integer cached key & update the expiry time
Parameters
- 
                string$key
- Identifier for the data 
- 
                int$offset optional
- How much to increment 
Returns
int|falseinit() ¶ public
init(array $config = []): boolInitialize the Cache Engine
Called automatically by the cache frontend
Parameters
- 
                array$config optional
- array of setting for the engine 
Returns
boolkey() ¶ public
key(string $key): string|falseGenerates a safe key for use with cache engine storage engines.
Parameters
- 
                string$key
- the key passed over 
Returns
string|falseread() ¶ public
read(string $key): mixedRead a key from the cache
Parameters
- 
                string$key
- Identifier for the data 
Returns
mixedreadMany() ¶ public
readMany(array $keys): arrayRead multiple keys from the cache
Parameters
- 
                array$keys
- An array of identifiers for the data 
Returns
arraysetConfig() ¶ public
setConfig(string|array $key, mixed|null $value = null, bool $merge = true): $thisSets the config.
Usage
Setting a specific value:
$this->setConfig('key', $value);Setting a nested value:
$this->setConfig('some.nested.key', $value);Updating multiple config settings at the same time:
$this->setConfig(['one' => 'value', 'another' => 'value']);Parameters
- 
                string|array$key
- The key to set, or a complete array of configs. 
- 
                mixed|null$value optional
- The value to set. 
- 
                bool$merge optional
- Whether to recursively merge or overwrite existing config, defaults to true. 
Returns
$thisThrows
Cake\Core\Exception\ExceptionWhen trying to set a key that is invalid.
warning() ¶ protected
warning(string $message): voidCache Engines may trigger warnings if they encounter failures during operation, if option warnOnWriteFailures is set to true.
Parameters
- 
                string$message
- The warning message. 
Returns
voidwrite() ¶ public
write(string $key, mixed $value): boolWrite data for key into cache.
Parameters
- 
                string$key
- Identifier for the data 
- 
                mixed$value
- Data to be cached 
Returns
boolwriteMany() ¶ public
writeMany(array $data): arrayWrite data for many keys into cache
Parameters
- 
                array$data
- An array of data to be stored in the cache 
Returns
arrayProperty Detail
$_configInitialized ¶ protected
Whether the config property has already been configured with defaults
Type
bool$_defaultConfig ¶ protected
The default config used unless overridden by runtime configuration
- databasedatabase number to use for connection.
- durationSpecify how long items in this cache configuration last.
- groupsList of groups or 'tags' associated to every key stored in this config. handy for deleting a complete group from cache.
- passwordRedis server password.
- persistentConnect to the Redis server with a persistent connection
- portport number to the Redis server.
- prefixPrefix appended to all entries. Good for when you need to share a keyspace with either another cache config or another application.
- probabilityProbability of hitting a cache gc cleanup. Setting to 0 will disable cache::gc from ever being called automatically.
- serverURL or ip to the Redis server host.
- timeouttimeout in seconds (float).
- unix_socketPath to the unix socket file (default: false)
Type
array$_groupPrefix ¶ protected
Contains the compiled string with all groups prefixes to be prepended to every key in this cache engine
Type
string