Zend_Cache-Introduction.xml 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.cache.introduction">
  5. <title>Introduction</title>
  6. <para>
  7. <classname>Zend_Cache</classname> fournit un moyen générique de mettre en cache des
  8. données.
  9. </para>
  10. <para>
  11. Le cache dans Zend Framework est réalisé via les frontends alors que les caches
  12. d'enregistrements sont stockés grâce à des adaptateurs de backend
  13. (<emphasis>File</emphasis>, <emphasis>Sqlite</emphasis>, <emphasis>Memcache</emphasis>...)
  14. grâce à un système souple d'ID et de balises. En les utilisant, il est simple de supprimer
  15. des types spécifiques d'enregistrements par la suite (par exemple: "supprime tous les
  16. enregistrements de cache marqués avec une balise donnée").
  17. </para>
  18. <para>
  19. Le coeur du module (<classname>Zend_Cache_Core</classname>) est générique, souple et
  20. configurable. Pour le moment, pour vos besoins spécifiques, il y a des frontends qui
  21. étendent <classname>Zend_Cache_Core</classname> simplement : <emphasis>Output</emphasis>,
  22. <emphasis>File</emphasis>, <emphasis>Function</emphasis> et <emphasis>Class</emphasis>.
  23. </para>
  24. <example id="zend.cache.introduction.example-1">
  25. <title>Créer un frontend avec Zend_Cache::factory()</title>
  26. <para>
  27. <methodname>Zend_Cache::factory()</methodname> instancie les objets corrects et les lie
  28. ensemble. Dans le premier exemple, nous allons utiliser le frontend
  29. <emphasis>Core</emphasis> avec le backend <emphasis>File</emphasis>.
  30. </para>
  31. <programlisting language="php"><![CDATA[
  32. $frontendOptions = array(
  33. 'lifetime' => 7200, // temps de vie du cache de 2 heures
  34. 'automatic_serialization' => true
  35. );
  36. $backendOptions = array(
  37. // Répertoire où stocker les fichiers de cache
  38. 'cache_dir' => './tmp/'
  39. );
  40. // créer un objet Zend_Cache_Core
  41. $cache = Zend_Cache::factory('Core',
  42. 'File',
  43. $frontendOptions,
  44. $backendOptions);
  45. ]]></programlisting>
  46. </example>
  47. <note>
  48. <title>Frontends et Backends constitués de plusieurs mots</title>
  49. <para>
  50. Certains frontends et backends sont nommés en utilisant plusieurs mots, comme
  51. "ZendPlatform". En les spécifiant à la fabrique, séparez les en utilisant
  52. un séparateur de mot, comme l'espace (" "), le tiret ("-") ou le point (".").
  53. </para>
  54. </note>
  55. <example id="zend.cache.introduction.example-2">
  56. <title>Mettre en cache un résultat de requête sur une base de données</title>
  57. <para>
  58. Maintenant que nous avons un frontend, nous pouvons mettre en cache tout type de
  59. données (nous avons activé la sérialisation). Par exemple nous pouvons mettre en cache
  60. le résultat d'une requête de base de données coûteuse. Après qu'il soit mis en cache,
  61. il n'y a plus besoin de se connecter à la base de données. Les enregistrements récupérés
  62. depuis le cache sont désérialisés.
  63. </para>
  64. <programlisting language="php"><![CDATA[
  65. // $cache initialisé dans l'exemple précédent
  66. // on regarde si un cache existe déjà
  67. if( ($result = $cache->load('myresult')) === false ) {
  68. // le cache est manquant, connexion à la base de données
  69. $db = Zend_Db::factory( [...] );
  70. $result = $db->fetchAll('SELECT * FROM grosse_table');
  71. $cache->save($result, 'myresult');
  72. } else {
  73. // il y a un cache
  74. echo "Ceci est issu du cache !\n\n";
  75. }
  76. print_r($result);
  77. ]]></programlisting>
  78. </example>
  79. <example id="zend.cache.introduction.example-3">
  80. <title>Cache de sortie avec le frontend de sortie Zend_Cache</title>
  81. <para>
  82. Nous marquons les sections dans lesquelles nous voulons un cache de sortie en
  83. ajoutant de la logique conditionnelle, en encapsulant la section entre les méthodes
  84. <methodname>start()</methodname> et <methodname>end()</methodname>
  85. (cela ressemble au premier exemple et est le coeur de la stratégie de mise en cache).
  86. </para>
  87. <para>
  88. A l'intérieur, affichez vos données comme d'habitude toutes les sorties seront
  89. misent en cache quand la méthode <methodname>end()</methodname> est appelée. A la
  90. prochaine exécution, la section complète sera évitée, au profit de la récupération de
  91. son cache (si le cache est encore valide).
  92. </para>
  93. <programlisting language="php"><![CDATA[
  94. $frontendOptions = array(
  95. // temps de vue du cache de 30 secondes
  96. 'lifetime' => 30,
  97. // par défaut
  98. 'automatic_serialization' => false
  99. );
  100. $backendOptions = array('cache_dir' => './tmp/');
  101. $cache = Zend_Cache::factory('Output',
  102. 'File',
  103. $frontendOptions,
  104. $backendOptions);
  105. // nous passons un identifiant unique de la méthode start()
  106. if(!$cache->start('mypage')) {
  107. // affichage
  108. echo 'Hello world! ';
  109. echo 'Ceci est issu du cache('.time().') ';
  110. // la sortie est sauvegardée est envoyé au navigateur
  111. $cache->end();
  112. }
  113. echo "Ceci n' jamais mis en cache (" . time() . ").";
  114. ]]></programlisting>
  115. <para>
  116. Notez que nous affichons le résultat de <methodname>time()</methodname> deux fois&#160;;
  117. c'est dans un but de démonstration. Essayez de lancer la page et de la rafraîchir
  118. plusieurs fois&#160;; vous allez constater que le premier nombre ne change pas alors
  119. que le second change à chaque actualisation. C'est parce que le premier nombre a été
  120. mis en cache et sauvegardé. Après 30 secondes ("lifeTime" a été mis à 30 secondes), le
  121. premier nombre devrait de nouveau correspondre au second nombre parce que le cache a
  122. expiré -- seulement pour être mis en cache de nouveau. Vous devriez essayer ce code
  123. dans votre navigateur ou dans une console.
  124. </para>
  125. </example>
  126. <note>
  127. <para>
  128. Lorsque vous utilisez <classname>Zend_Cache</classname>, faîtes attention à
  129. l'identifiant du cache (passé à <methodname>save()</methodname> et
  130. <methodname>start()</methodname>). Il doit
  131. être unique pour chaque ressource que vous mettez en cache, sinon il est possible que
  132. des caches en efface d'autres, ou encore pire, s'affiche en lieu et place d'autres.
  133. </para>
  134. </note>
  135. </sect1>