Zend_Cache-Introduction.xml 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15207 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.cache.introduction">
  5. <title>Einführung</title>
  6. <para>
  7. <classname>Zend_Cache</classname> bietet einen generellen Weg für das Cachen von Daten.
  8. </para>
  9. <para>
  10. Cachen im Zend Framework wird mit Frontends durchgeführt, wobei Cache Datensätze über Backend Adapter
  11. (<code>File</code>, <code>Sqlite</code>, <code>Memcached</code>...), durch ein flexibles System von
  12. IDs und Tags, gespeichert werden. Durch deren Verwendung ist es einfach, spezielle Typen von Datensätzen im
  13. Nachhinein zu Löschen (zum Beispiel: "Löschen aller Cache Datensätze welche mit einem bestimmten
  14. Tag markiert sind").
  15. </para>
  16. <para>
  17. Der Kern des Moduls (<classname>Zend_Cache_Core</classname>) ist generell, flexibel und konfigurierbar.
  18. Nun gibt es - für spezielle Bedürfnisse - Cache Frontends, welche <classname>Zend_Cache_Core</classname>
  19. erweitern: <code>Output</code>, <code>File</code>, <code>Function</code> und <code>Class</code>.
  20. </para>
  21. <example id="zend.cache.introduction.example-1">
  22. <title>Ein Frontend mit Zend_Cache::factory() erzeugen</title>
  23. <para>
  24. <classname>Zend_Cache::factory()</classname> instanziiert korrekte Objekte und fügt sie zusammen.
  25. In diesem ersten Beispiel wird das <code>Core</code> Frontend zusammen mit dem
  26. <code>File</code> Backend verwendet.
  27. </para>
  28. <programlisting role="php"><![CDATA[
  29. $frontendOptions = array(
  30. 'lifetime' => 7200, // Lebensdauer des Caches 2 Stunden
  31. 'automatic_serialization' => true
  32. );
  33. $backendOptions = array(
  34. 'cache_dir' => './tmp/' // Verzeichnis, in welches die Cache Dateien kommen
  35. );
  36. // Ein Zend_Cache_Core Objekt erzeugen
  37. $cache = Zend_Cache::factory('Core',
  38. 'File',
  39. $frontendOptions,
  40. $backendOptions);
  41. ]]></programlisting>
  42. </example>
  43. <note>
  44. <title>Frontends und Backends bestehend aus mehrfachen Wörtern</title>
  45. <para>
  46. Bei einige Frontends und Backends werden mehrere Wörter verwendet wie z.B. 'ZendPlatform'.
  47. Wenn diese der Fabrik spezifiziert werden, müssen diese aufgeteilt werden indem man ein
  48. Trennzeichen verwendet, wie z.B. das Leerzeichen (' '), Bindestrich ('-'), oder den Punkt ('.').
  49. </para>
  50. </note>
  51. <example id="zend.cache.introduction.example-2">
  52. <title>Das Ergebnis einer Datenbankabfrage cachen</title>
  53. <para>
  54. Jetzt, da wir ein Frontend haben, kann jeder Typ von Daten gecached werden (Serialisierung ist
  55. eingeschaltet). Zum Beispiel können Ergebnisse von sehr umfangreichen Datenbankabfragen
  56. gecached werden. Nach dem Cachen ist es sogar gar nicht nicht mehr notwendig, eine Verbindung
  57. zur Datenbank zu machen; Datensätze werden vom Cache genommen und deserialisiert.
  58. </para>
  59. <programlisting role="php"><![CDATA[
  60. // $cache initialisiert im vorhergehenden Beispiel
  61. // Nachsehen, ob der Cache bereits existiert:
  62. if(!$result = $cache->load('myresult')) {
  63. // Cache miss; mit Datenbank verbinden
  64. $db = Zend_Db::factory( [...] );
  65. $result = $db->fetchAll('SELECT * FROM huge_table');
  66. $cache->save($result, 'myresult');
  67. } else {
  68. // Cache hit! Ausgeben, damit wir es wissen
  69. echo "Der ist vom Cache!\n\n";
  70. }
  71. print_r($result);
  72. ]]></programlisting>
  73. </example>
  74. <example id="zend.cache.introduction.example-3">
  75. <title>Cache Ausgabe mit dem Zend_Cache Frontend</title>
  76. <para>
  77. Abschnitte, in denen die Ausgabe gecached werden soll, werden 'markiert', durch Hinzufügen
  78. von etwas bedingter Logik, wobei der Abschnitt innerhalb der <code>start()</code> und <code>end()</code> Methoden
  79. gekapselt wird (das ähnelt dem ersten Beispiel, und ist eine Kernstrategie für das Cachen).
  80. </para>
  81. <para>
  82. Darin muß die Ausgabe der Daten wie immer geschehen - jede Ausgabe wird gecached, wenn die Ausführung auf
  83. die <code>end()</code> Methode trifft. Bei der nächsten Ausführung wird der komplette Abschnitt
  84. übersprungen, dafür werden die Daten vom Cache geholt (solange der Cache Datensatz gültig ist).
  85. </para>
  86. <programlisting role="php"><![CDATA[
  87. $frontendOptions = array(
  88. 'lifetime' => 30, // Lebenszeit des Caches 30 Sekunden
  89. 'automatic_serialization' => false // Dieser Wert ist der Standardwert
  90. );
  91. $backendOptions = array('cache_dir' => './tmp/');
  92. $cache = Zend_Cache::factory('Output',
  93. 'File',
  94. $frontendOptions,
  95. $backendOptions);
  96. // Wir übergeben eine eindeutige Identifizierung an die start() Methode
  97. if(!$cache->start('mypage')) {
  98. // Ausgabe wie gewöhnlich:
  99. echo 'Hallo Welt! ';
  100. echo 'Das ist gecached ('.time().') ';
  101. $cache->end(); // Die Ausgabe wird gespeichert und zum Browser gesendet
  102. }
  103. echo 'Das wird nie gecached ('.time().').';
  104. ]]></programlisting>
  105. <para>
  106. Zu beachten ist das das Ergebnis von <code>time()</code> zweimal ausgegeben wird; das ist
  107. etwas dynamisches für Demonstrationszwecke. Beim Versuch dieses auszuführen und mehrfach zu
  108. refreshen, kann bemerkt werden, dass sich die erste Nummer nie ändert, während die zweite sich
  109. ändert, während die Zeit verstreicht. Das geschieht, weil die erste Nummer, die im gecacheten Abschnitt
  110. ausgegeben wird, im Gegensatz zur anderen Ausgabe gecached wurde.
  111. Nach einer halben Minute (die Lebensdauer wurde auf 30 Sekunden gesetzt) sind die Nummern
  112. wieder identisch, weil der Cache Eintrag abgelaufen ist - er muß wieder gecached werden.
  113. Man sollte das im Browser oder in der Konsole testen.
  114. </para>
  115. </example>
  116. <note><para>
  117. Wenn <classname>Zend_Cache</classname> benutzt wird, muß auf die wichtigen Cache Identifizierungen geachtet werden (welche an
  118. <code>save()</code> und <code>start()</code> übergeben werden). Diese müssen für jede Ressource
  119. einzigartig sein, die gecached werden soll. Andernfalls würden sich unverknüpfte Cache Datensätze gegenseitig
  120. entfernen oder, noch schlimmer, anstatt des anderen dargestellt werden.
  121. </para></note>
  122. </sect1>
  123. <!--
  124. vim:se ts=4 sw=4 et:
  125. +-->