Les backends Zend_Cache

Le gestionnaire de Cache

Une application comporte par nature plusieurs caches de types différents fonctions du contrôleur ou du modèle accédé. Afin de faciliter la création et la manipulation des options de Zend_Cache au plus tôt (par exemple en bootstrap), Zend_Cache_Manager a été créée. Cette classe est accompagnée de Zend_Application_Resource_Cachemanager pour tout ce qui concerne le bootstrap et Zend_Controller_Action_Helper_Cache afin d'accéder aux caches depuis les contrôleurs et autres aides d'action.

Le gestionnaire de cache utilise des templates, ce sont en fait des ensembles de configurations valides pour un cache. Ces templates s'enregistrent grâce à Zend_Cache_Manager::setCacheTemplate() et ne donnent naissance à un objet de cache que lorsque Zend_Cache_Manager::getCache() sera appelée.

  1. $manager = new Zend_Cache_Manager;
  2.  
  3. $dbCache = array(
  4.     'frontend' => array(
  5.         'name' => 'Core',
  6.         'options' => array(
  7.             'lifetime' => 7200,
  8.             'automatic_serialization' => true
  9.         )
  10.     ),
  11.     'backend' => array(
  12.         'name' => 'Core',
  13.         'options' => array(
  14.             'cache_dir' => '/path/to/cache'
  15.         )
  16.     )
  17. );
  18.  
  19. $manager->setCacheTemplate('database', $dbCache);
  20.  
  21. /**
  22. * Partout ailleurs où le gestionnaire de cache est accessible...
  23. */
  24. $databaseCache = $manager->getCache('database');

Le gestionnaire autorise aussi l'enregistrement d'objets de cache préalablement créés, ceci grâce à la méthode Zend_Cache_Manager::setCache().

  1. $frontendOptions = array(
  2.    'lifetime' => 7200,
  3.    'automatic_serialization' => true
  4. );
  5.  
  6. $backendOptions = array(
  7.     'cache_dir' => '/path/to/cache'
  8. );
  9.  
  10. $dbCache = Zend_Cache::factory('Core',
  11.                              'File',
  12.                              $frontendOptions,
  13.                              $backendOptions);
  14.  
  15. $manager = new Zend_Cache_Manager;
  16. $manager->setCache('database', $dbCache);
  17.  
  18. /**
  19. * Partout ailleurs où le gestionnaire de cache est accessible...
  20. */
  21. $databaseCache = $manager->getCache('database');

Si vous n'êtes pas sûr si le gestionnaire possède en lui un template de configuration ou un objet de cache déja enregistré, vérifiez celà grâce à Zend_Cache_Manager::hasCache().

  1. $manager = new Zend_Cache_Manager;
  2.  
  3. $dbCache = array(
  4.     'frontend' => array(
  5.         'name' => 'Core',
  6.         'options' => array(
  7.             'lifetime' => 7200,
  8.             'automatic_serialization' => true
  9.         )
  10.     ),
  11.     'backend' => array(
  12.         'name' => 'Core',
  13.         'options' => array(
  14.             'cache_dir' => '/path/to/cache'
  15.         )
  16.     )
  17. );
  18.  
  19. $manager->setCacheTemplate('database', $dbCache);
  20.  
  21. /**
  22. * Partout ailleurs où le gestionnaire de cache est accessible...
  23. */
  24. if ($manager->hasCache('database')) {
  25.     $databaseCache = $manager->getCache('database');
  26. } else {
  27.     // Créer un cache à la main puisque non trouvé dans le gestionnaire
  28. }

Dans certains cas, vous pouvez avoir défini un certain de cas d'utilisation avec Zend_Cache_Manager, mais vous avez besoin de préciser un option dans un cas particulier. Il est alors possible de modifier la configuration d'un template de cache après l'avoir saisie, ceci au moyen de Zend_Cache_Manager::setTemplateOptions().

  1. $manager = new Zend_Cache_Manager;
  2.  
  3. $dbCache = array(
  4.     'frontend' => array(
  5.         'name' => 'Core',
  6.         'options' => array(
  7.             'lifetime' => 7200,
  8.             'automatic_serialization' => true
  9.         )
  10.     ),
  11.     'backend' => array(
  12.         'name' => 'Core',
  13.         'options' => array(
  14.             'cache_dir' => '/path/to/cache'
  15.         )
  16.     )
  17. );
  18.  
  19. $manager->setCacheTemplate('database', $dbCache);
  20.  
  21. /**
  22. * Partout ailleurs où le gestionnaire de cache est accessible...
  23. * Ici nous changeons le support de stockage vers Memcache plutôt que ce
  24. * qu'il était avant : File.
  25. */
  26. $fineTuning = array(
  27.     'backend' => array(
  28.         'name' => 'Memcached',
  29.         'options' => array(
  30.             'servers' => array(
  31.                 array(
  32.                     'host' => 'localhost',
  33.                     'port' => 11211,
  34.                     'persistent' => true,
  35.                     'weight' => 1,
  36.                     'timeout' => 5,
  37.                     'retry_interval' => 15,
  38.                     'status' => true,
  39.                     'failure_callback' => ''
  40.                 )
  41.             )
  42.         )
  43.     )
  44. );
  45. $manager->setTemplateOptions('database', $fineTuning);
  46. $databaseCache = $manager->getCache('database');

Pour rendre le gestionnaire de cache plus utile, il est accompagné de Zend_Application_Resource_Cachemanager et Zend_Controller_Action_Helper_Cache. Toutes deux sont décrites dans leurs pages respectives de la documentation.

Aussi, Zend_Cache_Manager inclut déja quatre templates prédéfinis "skeleton", "default", "page" et "tagcache". Le cache "default" utilise des fichiers comme stockage et un Core comme frontend, il s'attend à posséder un dossier cache_dir appelé "cache" au même niveau que le dossier normalisé "public" dans une application Zend Framework. Le cache "skeleton" est un cache NULL, il ne comporte pas d'options. Les 2 autres caches sont utilisés avec des pages statiques dans lesquelles du HTML, XML ou encore JSON peut être stocké dans des fichiers statiques dans /public. Le contrôle sur les pages statiques est assuré par Zend_Controller_Action_Helper_Cache, même si vous pouvez changer les options "page", "tagcache" (par exemple) en utilisant Zend_Cache_Manager::setTemplateOptions() ou même Zend_Cache_Manager::setCacheTemplate().


Les backends Zend_Cache