Cache Framework
Flow offers a caching framework to cache data. The system offers a wide variety of options and storage solutions for different caching needs. Each cache can be configured individually and can implement its own specific storage strategy.
If configured correctly the caching framework can help to speed up installations, especially in heavy load scenarios. This can be done by moving all caches to a dedicated cache server with specialized cache systems like the Redis key-value store (a.k.a. NoSQL database), or shrinking the needed storage space by enabling compression of data.
Introduction
The caching framework can handle multiple caches with different configurations. A single cache consists of any number of cache entries. A single cache entry is defined by these parts:
- identifier
A string as unique identifier within this cache. Used to store and retrieve entries.
- data
The data to be cached.
- lifetime
A lifetime in seconds of this cache entry. The entry can not be retrieved from cache if lifetime expired.
- tags
Additional tags (an array of strings) assigned to the entry. Used to remove specific cache entries.
The difference between identifier and tags is hard to understand at first glance, it is illustrated with an example.
About the Identifier
The identifier used to store (“set”) and retrieve (“get”) entries from the cache holds all information to differentiate entries from each other. For performance reasons, it should be quick to calculate. Suppose there is an resource-intensive extension added as a plugin on two different pages. The calculated content depends on the page on which it is inserted and if a user is logged in or not. So, the plugin creates at maximum four different content outputs, which can be cached in four different cache entries:
page 1, no user logged in
page 1, a user is logged in
page 2, no user logged in
page 2, a user is logged in
To differentiate all entries from each other, the identifier is build from the page id
where the plugin is located, combined with the information whether a user is logged in.
These are concatenated and hashed (with sha1()
, for example). In PHP this could look
like this:
$identifier = sha1((string)$this->getName() . (string)$this->isUserLoggedIn());
When the plugin is accessed, the identifier is calculated early in the program flow. Next, the plugin looks up for a cache entry with this identifier. If there is such an entry, the plugin can return the cached content, else it calculates the content and stores a new cache entry with this identifier. In general the identifier is constructed from all dependencies which specify an unique set of data. The identifier should be based on information which already exist in the system at the point of its calculation. In the above scenario the page id and whether or not a user is logged in are already determined during the frontend bootstrap and can be retrieved from the system quickly.
System Architecture
The caching framework architecture is based on these classes:
Neos\Flow\Cache\CacheFactory
Factory class to instantiate caches.
Neos\Flow\Cache\CacheManager
Returns the cache frontend of a specific cache. Implements methods to handle cache instances.
Neos\Cache\Frontend\FrontendInterface
Interface to handle cache entries of a specific cache. Different frontends exist to handle different data types.
Neos\Cache\Backend\BackendInterface
Interface for different storage strategies. A set of implementations exist with different characteristics.
In your code you usually rely on dependency injection to have your caches injected.
Thus you deal mainly with the API defined in the FrontendInterface
.
Configuration
The cache framework is configured in the usual Flow way through YAML files. The most important is Caches.yaml, although you may of course use Objects.yaml to further configure the way your caches are used. Caches are given a (unique) name and have three keys in their configuration:
- frontend
The frontend to use for the cache.
- backend
The backend to use for the cache.
- backendOptions
The backend options to use.
- persistent
If the cache should stay persistent.
As an example for such a configuration take a look at the default that is inherited for any cache unless overridden:
Example: Default cache settings
##
# Default cache configuration
#
# If no frontend, backend or options are specified for a cache, these values
# will be taken to create the cache.
Default:
frontend: Neos\Cache\Frontend\VariableFrontend
backend: Neos\Cache\Backend\FileBackend
backendOptions:
defaultLifetime: 0
Some backends have mandatory as well as optional parameters (which are documented below). If not all mandatory options are defined, the backend will throw an exception on the first access. To override options for a cache, simply set them in Caches.yaml in your global or package Configuration directory.
Example: Configuration to use RedisBackend for FooCache
FooCache:
backend: Neos\Cache\Backend\RedisBackend
backendOptions:
database: 3
Persistent Cache
Caches can be marked as being “persistent” which lets the Cache Manager skip the cache while flushing all other caches or flushing caches by tag. Persistent caches make for a versatile and easy to use low-level key-value-store. Simple data like tokens, preferences or the like which usually would be stored in the file system, can be stored in such a cache. Flow uses a persistent cache for storing an encryption key for the Hash Service and Sessions. The configuration for this cache looks like this:
Example: Persistent cache settings
##
# Cache configuration for the HashService
#
# If no frontend, backend or options are specified for a cache, these values
# will be taken to create the cache.
Flow_Security_Cryptography_HashService:
backend: Neos\Cache\Backend\SimpleFileBackend
persistent: true
Note that, because the cache has been configured as “persistent”, the SimpleFileBackend will store its data in
Data/Persistent/Cache/Flow_Security_Cryptography_HashService/
instead of using the temporary directory
Data/Temporary/Production/Cache/Flow_Security_Cryptography_HashService/
. You can override the cache directory
by specifying it in the cache’s backend options.
Application Identifier
The application identifier can be used by cache backends to differentiate cache entries with the same cache identifier in the same storage from each other. For example memcache is global, so if you use it for multiple installations or possibly just for different Flow contexts you need to find a way to separate entries from each other. This setting will do that.
The default of %FLOW_PATH_ROOT%~%FLOW_APPLICATION_CONTEXT% is not well suited for installations in which the FLOW_PATH_ROOT changes after each deployment, so in such cases you might want to exchange it for some hardcoded value identifying each specific installation:
Neos:
Flow:
cache:
applicationIdentifier: 'some-unique-system-identifier'
Note
Changing the identifier will make cache entries generated with the old identifier useless.
Cache Frontends
Frontend API
All frontends must implement the API defined in the interface
Neos\Cache\Frontend\FrontendInterface
. All cache operations must be done
with these methods.
getIdentifier()
Returns the cache identifier.
getBackend()
Returns the backend instance of this cache. It is seldom needed in usual code.
set()
Sets/overwrites an entry in the cache.
get()
Return the cache entry for the given identifier.
getByTag()
Finds and returns all cache entries which are tagged by the specified tag.
has()
Check for existence of a cache entry.
remove()
Remove the entry for the given identifier from the cache.
flush()
Removes all cache entries of this cache.
flushByTag()
Flush all cache entries which are tagged with the given tag.
flushByTags()
Flush all cache entries which are tagged with any of the given tags.
collectGarbage()
Call the garbage collection method of the backend. This is important for backends which are unable to do this internally.
isValidIdentifier()
Checks if a given identifier is valid.
isValidTag()
Checks if a given tag is valid.
Check the API documentation for details on these methods.
Available Frontends
Currently three different frontends are implemented, the main difference is the data types which can be stored using a specific frontend.
Neos\Cache\Frontend\StringFrontend
The string frontend accepts strings as data to be cached.
Neos\Cache\Frontend\VariableFrontend
Strings, arrays and objects are accepted by this frontend. Data is serialized before it is given to the backend. The igbinary serializer is used transparently (if available in the system) which speeds up the serialization and unserialization and reduces data size. The variable frontend is the most frequently used frontend and handles the widest range of data types. While it can also handle string data, the string frontend should be used in this case to avoid the additional serialization done by the variable frontend.
Neos\Cache\Frontend\PhpFrontend
This is a special frontend to cache PHP files. It extends the string frontend with the method
requireOnce()
and allows PHP files to berequire()
’d if a cache entry exists.This can be used to cache and speed up loading of calculated PHP code and becomes handy if a lot of reflection and dynamic PHP class construction is done. A backend to be used with the PHP frontend must implement the
Neos\Cache\Backend\PhpCapableBackendInterface
Currently the file backend is the only backend which fulfills this requirement.
Note
The PHP frontend can only be used to cache PHP files, it does not work with strings, arrays or objects.
PSR Cache Interfaces
The implementations of the PSR Cache Interfaces allow to provide caches for external libraries that do not know the flow cache interfaces.
PSR-6 Caching Interface
The classes \Neos\Cache\Psr\Cache\CachePool
and \Neos\Cache\Psr\Cache\CacheItem
implement the Caching Interface as specified in https://www.php-fig.org/psr/psr-6/
PSR-16 Simple Cache Interface
The class \Neos\Cache\Psr\SimpleCache\SimpleCache
implements the SimpleCacheInterface
that is specified in https://www.php-fig.org/psr/psr-16/
Cache Backends
Currently already a number of different storage backends exists. They have different characteristics and can be used for different caching needs. The best backend depends on given server setup and hardware, as well as cache type and usage. A backend should be chosen wisely, a wrong decision could slow down an installation in the end.
Common Options
Common cache backend options
Options |
Description |
Mandatory |
Type |
Default |
---|---|---|---|---|
defaultLifeTime |
Default lifetime in seconds of a cache entry if it is not specified for a specific entry on set() |
No |
integer |
3600 |
Note
The SimpleFileBackend
does not support lifetime for cache entries!
Neos\Cache\Backend\SimpleFileBackend
The simple file backend stores every cache entry as a single file to the file system.
By default, cache entries will be stored in a directory below Data/Temporary/{context}/Cache/
.
For caches which are marked as persistent, the default directory is
Data/Persistent/Cache/
. You may override each of the defaults by specifying the cacheDirectory
backend option (see below).
The simple file backend implements the PhpCapableInterface
and can be used in
combination with the PhpFrontend
. The backend was specifically adapted to these
needs and has low overhead for get and set operations, it scales very well with the
number of entries for those operations. This mostly depends on the file lookup
performance of the underlying file system in large directories, and most modern file
systems use B-trees which can easily handle millions of files without much performance
impact.
Note
The SimpleFileBackend
is called like that, because it does not support lifetime for
cache entries! Nor does it support tagging cache entries!
Note
Under heavy load the maximum set()
performance depends on the maximum write and
seek performance of the hard disk. If for example the server system shows lots of I/O
wait in top, the file backend has reached this bound. A different storage strategy
like RAM disks, battery backed up RAID systems or SSD hard disks might help then.
Note
The SimpleFileBackend and FileBackend are the only cache backends that are capable of
storing the Flow_Object_Classes
Cache.
Options
Simple file cache backend options
Option |
Description |
Mandatory |
Type |
Default |
---|---|---|---|---|
cacheDirectory |
Full path leading to a custom cache directory. Example:
|
No |
string |
|
defaultLifeTime |
Cache entry lifetime is not supported in this backend. Entries never expire! |
No |
Neos\Cache\Backend\FileBackend
The file backend stores every cache entry as a single file to the file system. The lifetime and tags are added after the data part in the same file.
By default, cache entries will be stored in a directory below Data/Temporary/{context}/Cache/
.
For caches which are marked as persistent, the default directory is
Data/Persistent/Cache/
. You may override each of the defaults by specifying the cacheDirectory
backend option (see below).
The file backend implements the PhpCapableInterface
and can be used in combination
with the PhpFrontend
. The backend was specifically adapted to these needs and has
low overhead for get and set operations, it scales very well with the number of entries
for those operations. This mostly depends on the file lookup performance of the underlying
file system in large directories, and most modern file systems use B-trees which can
easily handle millions of files without much performance impact.
A disadvantage is that the performance of flushByTag()
is bad and scales just O(n).
This basically means that with twice the number of entries the file backend needs double
time to flush entries which are tagged with a given tag.
This practically renders the file backend unusable for content caches. The reason for this
design decision in Flow is that the file backend is mainly used as AOP cache, where
flushByTag()
is only used if a PHP file changes. This happens very seldom on
production systems, so get and set performance is much more important in this scenario.
Note
The SimpleFileBackend and FileBackend are the only cache backends that are capable of
storing the Flow_Object_Classes
Cache.
Options
File cache backend options
Option |
Description |
Mandatory |
Type |
Default |
---|---|---|---|---|
cacheDirectory |
Full path leading to a custom cache directory. Example:
|
No |
string |
Neos\Cache\Backend\PdoBackend
The PDO backend can be used as a native PDO interface to databases which are connected to PHP via PDO. The garbage collection is implemented for this backend and should be called to clean up hard disk space or memory.
Note
The definition for the cache tables can be found in the directory
Neos.Cache/Resources/Private/
.
The maximum size of each cache entry is limited to what a MEDIUMTEXT
type
can hold. When using MySQL/MariaDB that is 16MiB, other databases may have
a different limit.
Warning
This backend is php-capable. Nevertheless it cannot be used to store the proxy-classes
from the Flow_Object_Classes
Cache. It can be used for other code-caches like
Fluid_TemplateCache
, Eel_Expression_Code
or Flow_Aop_RuntimeExpressions
.
This can be usefull in certain situations to avoid file operations on production
environments. If you want to use this backend for code-caching make sure that
allow_url_include
is enabled in php.ini
Options
Pdo cache backend options
Option |
Description |
Mandatory |
Type |
Default |
---|---|---|---|---|
dataSourceName |
Data source name for connecting to the database. Examples:
|
Yes |
string |
|
username |
Username to use for the database connection. |
No |
||
password |
Password to use for the database connection. |
No |
||
cacheTableName |
Table name to store cache entries |
No |
string |
cache |
tagsTableName |
Table name to store cache tags |
No |
string |
tags |
batchSize |
Maximum number of parameters per query for batch operations. This value should be adjusted based on type of the data source to increase performance. E.g. Postgres supports up to 65535 parameters, but SQLite only 999 for older versions. |
No |
int |
999 |
Neos\Cache\Backend\RedisBackend
Redis is a key-value storage/database. In contrast to memcached, it allows structured values.Data is stored in RAM but it allows persistence to disk and doesn’t suffer from the design problems which exist with the memcached backend implementation. The redis backend can be used as an alternative of the database backend for big cache tables and helps to reduce load on database servers this way. The implementation can handle millions of cache entries each with hundreds of tags if the underlying server has enough memory.
Redis is known to be extremely fast but very memory hungry. The implementation is an option for big caches with lots of data because most important operations perform O(1) in proportion to the number of keys. This basically means that the access to an entry in a cache with a million entries is not slower than to a cache with only 10 entries, at least if there is enough memory available to hold the complete set in memory. At the moment only one redis server can be used at a time per cache, but one redis instance can handle multiple caches without performance loss when flushing a single cache.
The garbage collection task should be run once in a while to find and delete old tags.
The implementation is based on the phpredis module, which must be available on the system. It is recommended to build this from the git repository. Currently redis version 2.2 is recommended.
Note
It is important to monitor the redis server and tune its settings to the specific caching needs and hardware capabilities. There are several articles on the net and the redis configuration file contains some important hints on how to speed up the system if it reaches bounds. A full documentation of available options is far beyond this documentation.
Warning
The redis implementation is pretty young and should be considered as experimental. The redis project itself has a very high development speed and it might happen that the Flow implementation changes to adapt to new versions.
Warning
This backend is php-capable. Nevertheless it cannot be used to store the proxy-classes
from the FLOW_Object_Classes
Cache. It can be used for other code-caches like
Fluid_TemplateCache
, Eel_Expression_Code
or Flow_Aop_RuntimeExpressions
.
This can be usefull in certain situations to avoid file operations on production
environments. If you want to use this backend for code-caching make sure that
allow_url_include
is enabled in php.ini
Options
Redis cache backend options
Option |
Description |
Mandatory |
Type |
Default |
---|---|---|---|---|
hostname |
IP address or name of redis server to connect to |
No |
string |
127.0.0.1 |
port |
Port of the Redis server. |
Yes |
integer |
6379 |
database |
Number of the database to store entries. Each cache should use its own database, otherwise all caches sharing a database are flushed if the flush operation is issued to one of them. Database numbers 0 and 1 are used and flushed by the core unit tests and should not be used if possible. |
No |
integer |
0 |
password |
Password used to connect to the redis instance if the redis server needs authentication. Warning: The password is sent to the redis server in plain text. |
No |
string |
|
compressionLevel |
Set gzip compression level to a specific value. |
No |
integer (0 to 9) |
0 |
batchSize |
Maximum number of parameters per query for batch operations. Redis supports up to 1.048.576 parameters, but a lower batch size allows other calls to Redis to be processed between each batch. |
No |
int |
100000 |
Neos\Cache\Backend\MemcachedBackend
Memcached is a simple key/value RAM database which scales across multiple servers. To use this backend, at least one memcache daemon must be reachable, and the PHP module memcache must be loaded. There are two PHP memcache implementations: memcache and memcached, only memcache is currently supported by this backend.
Warning and Design Constraints
Memcached is by design a simple key-value store. Values must be strings and there is no relation between keys. Since the caching framework needs to put some structure in it to store the identifier-data-tags relations, it stores, for each cache entry, an identifier-to-data, an identifier-to-tags and a tag-to-identifiers entry.
This leads to structural problems:
- If memcache runs out of memory but must store new entries, it will toss some other
entry out of the cache (this is called an eviction in memcached speak).
- If data is shared over multiple memcache servers and some server fails, key/value pairs
on this system will just vanish from cache.
Both cases lead to corrupted caches: If, for example, a tags-to-identifier entry is lost,
dropByTag()
will not be able to find the corresponding identifier-to-data entries
which should be removed and they will not be deleted. This results in old data delivered
by the cache. Additionally, there is currently no implementation of the garbage collection
which can rebuild cache integrity. It is thus important to monitor a memcached system for
evictions and server outages and to clear clear caches if that happens.
Furthermore memcache has no sort of namespacing. To distinguish entries of multiple caches from each other, every entry is prefixed with the cache name. This can lead to very long runtimes if a big cache needs to be flushed, because every entry has to be handled separately and it is not possible to just truncate the whole cache with one call as this would clear the whole memcached data which might even hold non Flow related entries.
Because of the mentioned drawbacks, the memcached backend should be used with care or in situations where cache integrity is not important or if a cache has no need to use tags at all.
Note
The current native debian squeeze package (probably other distributions are affected, too) suffers from PHP memcache bug 16927.
Note
Since memcached has no sort of namespacing and access control, this backend should not be used if other third party systems do have access to the same memcached daemon for security reasons. This is a typical problem in cloud deployments where access to memcache is cheap (but could be read by third parties) and access to databases is expensive.
Warning
This backend is php-capable. Nevertheless it cannot be used to store the proxy-classes
from the FLOW_Object_Classes
Cache. It can be used for other code-caches like
Fluid_TemplateCache
, Eel_Expression_Code
or Flow_Aop_RuntimeExpressions
.
This can be usefull in certain situations to avoid file operations on production
environments. If you want to use this backend for code-caching make sure that
allow_url_include
is enabled in php.ini
Options
Memcached cache backend options
Option |
Description |
Mandatory |
Type |
Default |
---|---|---|---|---|
servers |
Array of used memcached servers, at least one server must be defined. Each server definition is a string, allowed syntaxes:
|
Yes |
array |
|
compression |
Enable memcached internal data compression. Can be used to reduce memcached memory consumption but adds additional compression / decompression CPU overhead on the according memcached servers. |
No |
boolean |
false |
Neos\Cache\Backend\ApcuBackend
APCu is also known as APC without opcode cache. It can be used to store user data. As main advantage the data can be shared between different PHP processes and requests. All calls are direct memory calls. This makes this backend lightning fast for get() and set() operations. It can be an option for relatively small caches (few dozens of megabytes) which are read and written very often.
The implementation is very similar to the memcached backend implementation and suffers from the same problems if APCu runs out of memory.
Note
It is not advisable to use the APCu backend in shared hosting environments for security reasons: The user cache in APCu is not aware of different virtual hosts. Basically every PHP script which is executed on the system can read and write any data to this shared cache, given data is not encapsulated or namespaced in any way. Only use the APCu backend in environments which are completely under your control and where no third party can read or tamper your data.
Warning
This backend is php-capable. Nevertheless it cannot be used to store the proxy-classes
from the Flow_Object_Classes
Cache. It can be used for other code-caches like
Fluid_TemplateCache
, Eel_Expression_Code
or Flow_Aop_RuntimeExpressions
.
This can be useful in certain situations to avoid file operations on production
environments. If you want to use this backend for code-caching make sure that
allow_url_include
is enabled in php.ini
Options
The APCu backend has no options.
Neos\Cache\Backend\TransientMemoryBackend
The transient memory backend stores data in a local array. It is only valid for one request. This becomes handy if code logic needs to do expensive calculations or must look up identical information from a database over and over again during its execution. In this case it is useful to store the data in an array once and just lookup the entry from the cache for consecutive calls to get rid of the otherwise additional overhead. Since caches are available system wide and shared between core and extensions they can profit from each other if they need the same information.
Since the data is stored directly in memory, this backend is the quickest backend
available. The stored data adds to the memory consumed by the PHP process and can hit the
memory_limit
PHP setting.
Options
The transient memory backend has no options.
Neos\Cache\Backend\NullBackend
The null backend is a dummy backend which doesn’t store any data and always returns
false
on get()
.
Options
The null backend has no options.
Neos\Cache\Backend\MultiBackend
This backend accepts several backend configurations to be used in order of appearance as a fallback mechanism should one of them not be available. For example, you might want to configure the first backend be a RedisBackend and, as a fallback, configure a second cache backend based on the FileBackend, which steps in if Redis is unavailable.
If backendConfigurations is an empty array this will act just like the NullBackend.
Warning
Due to the nature of this backend as fallback it will swallow all errors on creating and using the sub backends. So configuration errors won’t show up. See debug option.
Whenever an error occurs while using a configured backend, the error will be caught, logged, and the backend is flagged as “unhealthy” for the remainder of the request. The next operation (for example, a “get()” or “set()” call) will use the next healthy backend. If there is only one backend left and it causes an error, MultiBackend will still try to use it on the next operation.
You can disable the the removal of unhealthy backends with a backend option.
Options
Multi cache backend options
Option |
Description |
Mandatory |
Type |
Default |
---|---|---|---|---|
setInAllBackends |
Should values given to the backend be replicated into all configured and available backends? Generally that is desirable for fallback purposes, but to avoid too much duplication at the cost of performance on fallbacks this can be disabled. |
No |
bool |
true |
backendConfigurations |
A list of backends to be used in order of appearance. Each entry in that list should have the keys “backend” and “backendOptions” just as a top level backend configuration. |
Yes |
array |
[] |
debug |
Switch on debug mode which will throw any errors happening in sub backends. Use this in development to make sure everything works as expected. |
No |
bool |
false |
logErrors |
Log errors reported by the individual sub backends and when a backend is flagged as unhealthy. |
No |
bool |
true |
removeUnhealthyBackends |
Automatically remove a sub backend from the list of cache backends, in case it any errors. The sub backend will be used again at the next CLI / web request. |
No |
bool |
true |
Neos\Cache\Backend\TaggableMultiBackend
Technically all the same as the MultiBackend above but implements the TaggableBackendInterface and so supports tagging.
Options are the same as for the MultiBackend.
Neos\Cache\Backend\IterableMultiBackend
The IterableMultiBackend is an extension of the TaggableMultiBackend and additionally implements the IterableBackendInterface. Backends of this type can be used for caches which require iteration support, such as the Flow session cache.
Options are the same as for the MultiBackend.
How to Use the Caching Framework
This section is targeted at developers who want to use caches for arbitrary needs. It is only about proper initialization, not a discussion about identifier, tagging and lifetime decisions that must be taken during development.
Register a Cache
To register a cache it must be configured in Caches.yaml of a package:
MyPackage_FooCache:
frontend: Neos\Cache\Frontend\StringFrontend
In this case \Neos\Cache\Frontend\StringFrontend
was chosen, but that depends
on individual needs. This setting is usually not changed by users. Any option not given is
inherited from the configuration of the “Default” cache. The name (MyPackage_FooCache
in this case) can be chosen freely, but keep possible name clashes in mind and adopt a
meaningful schema.
Retrieve and Use a Cache
Using dependency injection
A cache is usually retrieved through dependency injection, either constructor or setter
injection. Which is chosen depends on when you need the cache to be available. Keep in
mind that even if you seem to need a cache in the constructor, you could always make use
of initializeObject()
. Here is an example for setter injection matching the
configuration given above. First you need to configure the injection in Objects.yaml:
MyCompany\MyPackage\SomeClass:
properties:
fooCache:
object:
factoryObjectName: Neos\Flow\Cache\CacheManager
factoryMethodName: getCache
arguments:
1:
value: MyPackage_FooCache
This configures what will be injected into the following setter:
/**
* Sets the foo cache
*
* @param \Neos\Cache\Frontend\StringFrontend $cache Cache for foo data
*/
public function setFooCache(\Neos\Cache\Frontend\StringFrontend $cache): void
{
$this->fooCache = $cache;
}
or injected class property:
/**
* @Flow\Inject
* @var \Neos\Cache\Frontend\StringFrontend $cache
*/
protected $cache;
To make it even simpler you could omit the setter method and annotate the member with the
Inject
annotations. The injected cache is fully initialized, all available frontend
operations like get()
, set()
and flushByTag()
can be executed on $this->fooCache
.
For configuring PSR Caches the factoryMethods used in the Objects.yaml have to be adjusted:
MyCompany\MyPackage\SomeClass:
properties:
# PSR-6
cacheItemPool:
object:
factoryObjectName: Neos\Flow\Cache\CacheManager
factoryMethodName: getCacheItemPool
arguments:
1:
value: MyPackage_CacheItemPool
# PSR-16
simpleCache:
object:
factoryObjectName: Neos\Flow\Cache\CacheManager
factoryMethodName: getSimpleCache
arguments:
1:
value: MyPackage_SimpleCache
This configures what will be injected into the following properties:
/**
* @Flow\Inject
* @var \Psr\Cache\CacheItemPoolInterface $cache
*/
protected $cacheItemPool:
/**
* @Flow\Inject
* @var \Psr\SimpleCache\CacheInterface $cache
*/
protected $simpleCache;
Using the CacheFactory
Of course you can also manually ask the CacheManager (have it injected for your convenience) for a cache:
$this->fooCache = $this->cacheManager->getCache('MyPackage_FooCache');
To retrieve PSR Cache implementations the cache manager provides methods to get PSR-6 CacheItemPool PSR-16 SimpleCache implementations for a given cache identifier:
$this->simpleCache = $this->cacheManager->getSimpleCache('MyPackage_SimpleCache');
$this->cacheItemPool = $this->cacheManager->getCacheItemPool('MyPackage_CacheItemPool');
Warning
While possible it is not advisible to access the same cache with different interfaces as the storage formats may differ!