Zend_Cache

Introduction

Zend_Cache fournit un moyen générique de mettre en cache des données.

Le cache dans Zend Framework est réalisé via les frontends alors que les caches d'enregistrements sont stockés grâce à des adaptateurs de backend (File, Sqlite, Memcache...) grâce à un système souple d'ID et de balises. En les utilisant, il est simple de supprimer des types spécifiques d'enregistrements par la suite (par exemple: "supprime tous les enregistrements de cache marqués avec une balise donnée").

Le coeur du module (Zend_Cache_Core) est générique, souple et configurable. Pour le moment, pour vos besoins spécifiques, il y a des frontends qui étendent Zend_Cache_Core simplement : Output, File, Function et Class.

Example #1 Créer un frontend avec Zend_Cache::factory()

Zend_Cache::factory() instancie les objets corrects et les lie ensemble. Dans le premier exemple, nous allons utiliser le frontend Core avec le backend File.

  1. $frontendOptions = array(
  2.    'lifetime' => 7200, // temps de vie du cache de 2 heures
  3.    'automatic_serialization' => true
  4. );
  5.  
  6. $backendOptions = array(
  7.     // Répertoire où stocker les fichiers de cache
  8.     'cache_dir' => './tmp/'
  9. );
  10.  
  11. // créer un objet Zend_Cache_Core
  12. $cache = Zend_Cache::factory('Core',
  13.                              'File',
  14.                              $frontendOptions,
  15.                              $backendOptions);

Note: Frontends et Backends constitués de plusieurs mots
Certains frontends et backends sont nommés en utilisant plusieurs mots, comme "ZendPlatform". En les spécifiant à la fabrique, séparez les en utilisant un séparateur de mot, comme l'espace (" "), le tiret ("-") ou le point (".").

Example #2 Mettre en cache un résultat de requête sur une base de données

Maintenant que nous avons un frontend, nous pouvons mettre en cache tout type de données (nous avons activé la sérialisation). Par exemple nous pouvons mettre en cache le résultat d'une requête de base de données coûteuse. Après qu'il soit mis en cache, il n'y a plus besoin de se connecter à la base de données. Les enregistrements récupérés depuis le cache sont désérialisés.

  1. // $cache initialisé dans l'exemple précédent
  2.  
  3. // on regarde si un cache existe déjà
  4. if(!$result = $cache->load('myresult')) {
  5.  
  6.     // le cache est manquant, connexion à la base de données
  7.     $db = Zend_Db::factory( [...] );
  8.  
  9.     $result = $db->fetchAll('SELECT * FROM grosse_table');
  10.  
  11.     $cache->save($result, 'myresult');
  12.  
  13. } else {
  14.  
  15.     // il y a un cache
  16.     echo "Ceci est issu du cache !\n\n";
  17.  
  18. }
  19.  
  20. print_r($result);

Example #3 Cache de sortie avec le frontend de sortie Zend_Cache

Nous marquons les sections dans lesquelles nous voulons un cache de sortie en ajoutant de la logique conditionnelle, en encapsulant la section entre les méthodes start() et end() (cela ressemble au premier exemple et est le coeur de la stratégie de mise en cache).

A l'intérieur, affichez vos données comme d'habitude toutes les sorties seront misent en cache quand la méthode end() est appelée. A la prochaine exécution, la section complète sera évitée, au profit de la récupération de son cache (si le cache est encore valide).

  1. $frontendOptions = array(
  2.     // temps de vue du cache de 30 secondes
  3.     'lifetime' => 30,
  4.     // par défaut
  5.     'automatic_serialization' => false
  6. );
  7.  
  8. $backendOptions = array('cache_dir' => './tmp/');
  9.  
  10. $cache = Zend_Cache::factory('Output',
  11.                              'File',
  12.                              $frontendOptions,
  13.                              $backendOptions);
  14.  
  15. // nous passons un identifiant unique de la méthode start()
  16. if(!$cache->start('mypage')) {
  17.     // affichage
  18.  
  19.     echo 'Hello world! ';
  20.     echo 'Ceci est issu du cache('.time().') ';
  21.  
  22.     // la sortie est sauvegardée est envoyé au navigateur
  23.     $cache->end();
  24. }
  25.  
  26. echo "Ceci n' jamais mis en cache (" . time() . ").";

Notez que nous affichons le résultat de time() deux fois ; c'est dans un but de démonstration. Essayez de lancer la page et de la rafraîchir plusieurs fois ; vous allez constater que le premier nombre ne change pas alors que le second change à chaque actualisation. C'est parce que le premier nombre a été mis en cache et sauvegardé. Après 30 secondes ("lifeTime" a été mis à 30 secondes), le premier nombre devrait de nouveau correspondre au second nombre parce que le cache a expiré -- seulement pour être mis en cache de nouveau. Vous devriez essayer ce code dans votre navigateur ou dans une console.

Note: Lorsque vous utilisez Zend_Cache, faîtes attention à l'identifiant du cache (passé à save() et start()). Il doit être unique pour chaque ressource que vous mettez en cache, sinon il est possible que des caches en efface d'autres, ou encore pire, s'affiche en lieu et place d'autres.


Zend_Cache