Zend_Cache-Backends.xml 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15740 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.cache.backends">
  5. <title>Zend_Cache Backends</title>
  6. <para>
  7. Es gibt zwei Arten von Backends: Standard und erweiterte. Natürlich bieten erweiterte
  8. Backends mehr Features.
  9. </para>
  10. <sect2 id="zend.cache.backends.file">
  11. <title>Zend_Cache_Backend_File</title>
  12. <para>
  13. Dieses (erweiterte) Backend speichert Cache Datensätze in Dateien (in einem gewählten
  14. Verzeichnis).
  15. </para>
  16. <para>
  17. Mögliche Optionen sind :
  18. </para>
  19. <table id="zend.cache.backends.file.table">
  20. <title>File Backend Optionen</title>
  21. <tgroup cols="4">
  22. <thead>
  23. <row>
  24. <entry>Option</entry>
  25. <entry>Daten Typ</entry>
  26. <entry>Standardwert</entry>
  27. <entry>Beschreibung</entry>
  28. </row>
  29. </thead>
  30. <tbody>
  31. <row>
  32. <entry><emphasis>cache_dir</emphasis></entry>
  33. <entry><type>String</type></entry>
  34. <entry><filename>'/tmp/'</filename></entry>
  35. <entry>
  36. Verzeichnis, in dem die Cache Dateien gespeichert werden
  37. </entry>
  38. </row>
  39. <row>
  40. <entry><emphasis>file_locking</emphasis></entry>
  41. <entry><type>Boolean</type></entry>
  42. <entry><constant>TRUE</constant></entry>
  43. <entry>
  44. Ein- / Ausschalten von file_locking: kann die Beschädigung des Caches
  45. unter schlechten Bedingungen verhindern, aber es hilft nicht bei
  46. Multithreaded Webservern oder bei NFS Filesystemen...
  47. </entry>
  48. </row>
  49. <row>
  50. <entry><emphasis>read_control</emphasis></entry>
  51. <entry><type>Boolean</type></entry>
  52. <entry><constant>TRUE</constant></entry>
  53. <entry>
  54. Ein- / Ausschalten von read_control: eingeschaltet wird ein
  55. Kontrollschlüssel im Cache File inkludiert und dieser Schlüssel wird mit
  56. dem Schlüssel verglichen, der nach dem Lesen berechnet wird.
  57. </entry>
  58. </row>
  59. <row>
  60. <entry><emphasis>read_control_type</emphasis></entry>
  61. <entry><type>String</type></entry>
  62. <entry>'crc32'</entry>
  63. <entry>
  64. Typ der Schreibkontrolle (nur wenn read_control eingeschaltet ist).
  65. Mögliche Werte sind : 'md5' (bestes, aber am Langsamsten), 'crc32'
  66. (etwas weniger sicher, aber schneller, beste Wahl), 'adler32' (neue
  67. Wahl, schneller als crc32), 'strlen' um nur die Länge zu testen
  68. (schnellstes).
  69. </entry>
  70. </row>
  71. <row>
  72. <entry><emphasis>hashed_directory_level</emphasis></entry>
  73. <entry><type>Integer</type></entry>
  74. <entry>0</entry>
  75. <entry>
  76. Level der gehashten Verzeichnis Struktur: 0 heißt "keine gehashte
  77. Verzeichnis Strutur, 1 heißt "ein Level von Verzeichnissen", 2 heißt
  78. "zwei Levels"... Diese Option kann den Cache nur dann schneller machen,
  79. wenn viele Tausende Cache Dateien verwendet werden. Nur spezielle
  80. Messungen können helfen, den perfekten Wert zu finden. Möglicherweise
  81. ist 1 oder 2 ein guter Anfang.
  82. </entry>
  83. </row>
  84. <row>
  85. <entry><emphasis>hashed_directory_umask</emphasis></entry>
  86. <entry><type>Integer</type></entry>
  87. <entry>0700</entry>
  88. <entry>
  89. Umask für die gehashte Verzeichnis Struktur
  90. </entry>
  91. </row>
  92. <row>
  93. <entry><emphasis>file_name_prefix</emphasis></entry>
  94. <entry><type>String</type></entry>
  95. <entry>'zend_cache'</entry>
  96. <entry>
  97. Präfix für Cache Dateien; man muss mit dieser Option sehr vorsichtig
  98. umgehen, weil ein zu generischer Wert in einem System Cache
  99. Verzeichnis (wie /tmp) kann beim Löschen des Caches zu großen
  100. Problemen führen.
  101. </entry>
  102. </row>
  103. <row>
  104. <entry><emphasis>cache_file_umask</emphasis></entry>
  105. <entry><type>Integer</type></entry>
  106. <entry>0700</entry>
  107. <entry>
  108. umask nach Cache Dateien
  109. </entry>
  110. </row>
  111. <row>
  112. <entry><emphasis>metatadatas_array_max_size</emphasis></entry>
  113. <entry><type>Integer</type></entry>
  114. <entry>100</entry>
  115. <entry>
  116. Interne maximale Größe für das Metadaten Array (dieser Wert sollte
  117. nicht geändert werden außer man weiß was man macht)
  118. </entry>
  119. </row>
  120. </tbody>
  121. </tgroup>
  122. </table>
  123. </sect2>
  124. <sect2 id="zend.cache.backends.sqlite">
  125. <title>Zend_Cache_Backend_Sqlite</title>
  126. <para>
  127. Dieses (erweiterte) Backend speichert die Cache Datensätze in einer SQLite Datenbank.
  128. </para>
  129. <para>
  130. Mögliche Optionen sind :
  131. </para>
  132. <table id="zend.cache.backends.sqlite.table">
  133. <title>Sqlite Backend Optionen</title>
  134. <tgroup cols="4">
  135. <thead>
  136. <row>
  137. <entry>Option</entry>
  138. <entry>Daten Typ</entry>
  139. <entry>Standardwert</entry>
  140. <entry>Beschreibung</entry>
  141. </row>
  142. </thead>
  143. <tbody>
  144. <row>
  145. <entry><emphasis>cache_db_complete_path (mandatory)</emphasis></entry>
  146. <entry><type>String</type></entry>
  147. <entry><constant>NULL</constant></entry>
  148. <entry>
  149. Der komplette Pfad (inklusive Dateiname) der SQLite Datenbank
  150. </entry>
  151. </row>
  152. <row>
  153. <entry><emphasis>automatic_vacuum_factor</emphasis></entry>
  154. <entry><type>Integer</type></entry>
  155. <entry>10</entry>
  156. <entry>
  157. Deaktiviere / stelle den automatischen Vakuumprozess ein.
  158. Der automatische Vakuumprozess defragmentiert die Datenbankdatei (und
  159. verkleinert sie) wenn clean() oder delete() aufgerufen wird:
  160. 0 bedeutet kein automatisches Vakuum; 1 bedeutet systematisches Vakuum
  161. (wenn die delete() or clean() Methoden aufgerufen werden; x (integer)
  162. > 1 => automatisches Vakuum zufällig einmal pro x clean() oder
  163. delete() Aufrufe.
  164. </entry>
  165. </row>
  166. </tbody>
  167. </tgroup>
  168. </table>
  169. </sect2>
  170. <sect2 id="zend.cache.backends.memcached">
  171. <title>Zend_Cache_Backend_Memcached</title>
  172. <para>
  173. Dieses (erweiterte) Backend speichert Cache Datensätze in einem Memcached Server. <ulink
  174. url="http://www.danga.com/memcached/">memcached</ulink> ist ein hoch-performantes,
  175. verteiltes Speicher Objekt Caching System. Um dieses Backend zu benutzen, wird ein
  176. Memcached Dämon benötigt und <ulink url="http://pecl.php.net/package/memcache">die
  177. Memcached PECL Erweiterung</ulink>.
  178. </para>
  179. <para>
  180. Vorsicht: mit diesem Backend werden zur Zeit "Marker" nicht unterstützt genauso wie das
  181. "doNotTestCacheValidity=true" Argument.
  182. </para>
  183. <para>
  184. Mögliche Optionen sind :
  185. </para>
  186. <table id="zend.cache.backends.memcached.table">
  187. <title>Memcached Backend Optionen</title>
  188. <tgroup cols="4">
  189. <thead>
  190. <row>
  191. <entry>Option</entry>
  192. <entry>Daten Typ</entry>
  193. <entry>Standardwert</entry>
  194. <entry>Beschreibung</entry>
  195. </row>
  196. </thead>
  197. <tbody>
  198. <row>
  199. <entry><emphasis>servers</emphasis></entry>
  200. <entry><type>Array</type></entry>
  201. <entry>
  202. array(array('host' => 'localhost','port' => 11211, 'persistent' =>
  203. true, 'weight' => 1, 'timeout' => 5, 'retry_interval' => 15,
  204. 'status' => true, 'failure_callback' => '' ))
  205. </entry>
  206. <entry>
  207. Ein Array von Memcached Servern; jeder Memcached Server wird durch ein
  208. assoziatives Array beschrieben : 'host' => (string) : Der Name des
  209. Memcached Servers, 'port' => (int) : Der Port des Memcached Servers,
  210. 'persistent' => (bool) : Persistente Verbindungen für diesen Memcached
  211. Server verwenden oder nicht 'weight' => (int) : Das Gewicht des
  212. Memcached Servers, 'timeout' => (int) : Das Timeout des Memcached
  213. Servers, 'retry_interval' => (int) : Das Wiederholungsintervall des
  214. Memcached Servers, 'status' => (bool) : Der Status des Memcached
  215. Servers, 'failure_callback' => (callback) : Der failure_callback des
  216. Memcached Servers
  217. </entry>
  218. </row>
  219. <row>
  220. <entry><emphasis>compression</emphasis></entry>
  221. <entry><type>Boolean</type></entry>
  222. <entry><constant>FALSE</constant></entry>
  223. <entry>
  224. true wenn on-the-fly Kompression verwendet werden soll
  225. </entry>
  226. </row>
  227. <row>
  228. <entry><emphasis>compatibility</emphasis></entry>
  229. <entry><type>Boolean</type></entry>
  230. <entry><constant>FALSE</constant></entry>
  231. <entry>
  232. true wenn man den Compatibility Modus mit alten Memcache
  233. Servern/Erweiterungen verwenden will
  234. </entry>
  235. </row>
  236. </tbody>
  237. </tgroup>
  238. </table>
  239. </sect2>
  240. <sect2 id="zend.cache.backends.apc">
  241. <title>Zend_Cache_Backend_Apc</title>
  242. <para>
  243. Dieses (erweiterte) Backend speichert Cache Datensätze im Shared Memory durch die
  244. <ulink url="http://pecl.php.net/package/APC">APC</ulink> (Alternativer PHP Cache)
  245. Erweiterung (welche natürlich für die Verwendung dieses Backends benötigt wird).
  246. </para>
  247. <para>
  248. Vorsicht: mit diesem Backend werden "Marker" zur Zeit nicht unterstützt genauso wie das
  249. "doNotTestCacheValidity=true" Argument.
  250. </para>
  251. <para>
  252. Es gibt keine Optionen für dieses Backend.
  253. </para>
  254. </sect2>
  255. <sect2 id="zend.cache.backends.xcache">
  256. <title>Zend_Cache_Backend_Xcache</title>
  257. <para>
  258. Dieses Backend speichert Cache Einträge im Shared Memory durch die
  259. <ulink url="http://xcache.lighttpd.net/">XCache</ulink> Erweiterung (welche natürlich
  260. benötigt wird, damit dieses Backend verwendet werden kann).
  261. </para>
  262. <para>
  263. Achtung: Bei diesem Backend werden "tags" aktuell nicht unterstützt sowie das
  264. "doNotTestCacheValidity=true" Argument.
  265. </para>
  266. <para>
  267. Mögliche Optionen sind:
  268. </para>
  269. <table id="zend.cache.backends.xcache.table">
  270. <title>Xcache backend options</title>
  271. <tgroup cols="4">
  272. <thead>
  273. <row>
  274. <entry>Option</entry>
  275. <entry>Daten Typ</entry>
  276. <entry>Standardwert</entry>
  277. <entry>Beschreibung</entry>
  278. </row>
  279. </thead>
  280. <tbody>
  281. <row>
  282. <entry><emphasis>user</emphasis></entry>
  283. <entry><type>String</type></entry>
  284. <entry><constant>NULL</constant></entry>
  285. <entry>
  286. xcache.admin.user, notwendig für die clean() Methode
  287. </entry>
  288. </row>
  289. <row>
  290. <entry><emphasis>password</emphasis></entry>
  291. <entry><type>String</type></entry>
  292. <entry><constant>NULL</constant></entry>
  293. <entry>
  294. xcache.admin.pass (in offener Form, nicht MD5), notwendig für die
  295. clean() Methode
  296. </entry>
  297. </row>
  298. </tbody>
  299. </tgroup>
  300. </table>
  301. </sect2>
  302. <sect2 id="zend.cache.backends.platform">
  303. <title>Zend_Cache_Backend_ZendPlatform</title>
  304. <para>
  305. Dieses Backend verwendet die Content Caching API des
  306. <ulink url="http://www.zend.com/products/platform">Zend Platform</ulink> Produktes.
  307. Natürlich muss man die Zend Platform installiert haben, um dieses Backend verwenden zu
  308. können.
  309. </para>
  310. <para>
  311. Dieses Backend unterstützt Tags, aber nicht den
  312. <constant>CLEANING_MODE_NOT_MATCHING_TAG</constant> Löschmodus.
  313. </para>
  314. <para>
  315. Bei Definition dieses Backends muß ein Trennzeichen -- '-', '.', ' ', oder '_'
  316. -- zwischen den Wörtern 'Zend' und 'Platform' definiert sein wenn die
  317. <classname>Zend_Cache::factory()</classname> Methode verwendet wird:
  318. </para>
  319. <programlisting language="php"><![CDATA[
  320. $cache = Zend_Cache::factory('Core', 'Zend Platform');
  321. ]]></programlisting>
  322. <para>
  323. Es gibt keine Optionen für dieses Backend.
  324. </para>
  325. </sect2>
  326. <sect2 id="zend.cache.backends.twolevels">
  327. <title>Zend_Cache_Backend_TwoLevels</title>
  328. <para>
  329. Dieses (erweiterte) Backend ist ein Hybrides. Es speichert Cache Einträge in zwei
  330. anderen Backends: Ein schnelles (aber limitiertes) wie Apc, Memcache... und ein
  331. "langsames" wie File, Sqlite...
  332. </para>
  333. <para>
  334. Dieses Backend verwendet den Priority Parameter (der auf Frontend Level angegeben wird
  335. wenn ein Eintrag gespeichert wird) und den verbleibenden Platz im schnellen Backend um
  336. die Verwendung dieser zwei Backends zu optimieren.
  337. FIXME
  338. </para>
  339. <para>
  340. Vorhandene Optionen sind:
  341. </para>
  342. <table id="zend.cache.backends.twolevels.table">
  343. <title>TwoLevels Backend Optionen</title>
  344. <tgroup cols="4">
  345. <thead>
  346. <row>
  347. <entry>Option</entry>
  348. <entry>Datentyp</entry>
  349. <entry>Standardwert</entry>
  350. <entry>Beschreibung</entry>
  351. </row>
  352. </thead>
  353. <tbody>
  354. <row>
  355. <entry><emphasis>slow_backend</emphasis></entry>
  356. <entry><type>String</type></entry>
  357. <entry>File</entry>
  358. <entry>
  359. Der "langsame" Backendname
  360. </entry>
  361. </row>
  362. <row>
  363. <entry><emphasis>fast_backend</emphasis></entry>
  364. <entry><type>String</type></entry>
  365. <entry>Apc</entry>
  366. <entry>
  367. Der "schnelle" Backendname
  368. </entry>
  369. </row>
  370. <row>
  371. <entry><emphasis>slow_backend_options</emphasis></entry>
  372. <entry><type>Array</type></entry>
  373. <entry><methodname>array()</methodname></entry>
  374. <entry>
  375. Die "langsamen" Backendoptionen
  376. </entry>
  377. </row>
  378. <row>
  379. <entry><emphasis>fast_backend_options</emphasis></entry>
  380. <entry><type>Array</type></entry>
  381. <entry><methodname>array()</methodname></entry>
  382. <entry>
  383. Die "schnellen" Backendoptionen
  384. </entry>
  385. </row>
  386. <row>
  387. <entry><emphasis>slow_backend_custom_naming</emphasis></entry>
  388. <entry><type>Boolean</type></entry>
  389. <entry><constant>FALSE</constant></entry>
  390. <entry>
  391. Wenn true, wird das slow_backend Argument als kompletter Klassenname
  392. verwendet; wenn false, wird das frontend Argument als Ende des
  393. "Zend_Cache_Backend_[...]" Klassennamens verwendet
  394. </entry>
  395. </row>
  396. <row>
  397. <entry><emphasis>fast_backend_custom_naming</emphasis></entry>
  398. <entry><type>Boolean</type></entry>
  399. <entry><constant>FALSE</constant></entry>
  400. <entry>
  401. Wenn true, wird das fast_backend Argument als kompletter Klassenname
  402. verwendet; wenn false, wird das frontend Argument als Ende des
  403. "Zend_Cache_Backend_[...]" Klassennamens verwendet
  404. </entry>
  405. </row>
  406. <row>
  407. <entry><emphasis>slow_backend_autoload</emphasis></entry>
  408. <entry><type>Boolean</type></entry>
  409. <entry><constant>FALSE</constant></entry>
  410. <entry>
  411. Wenn true, wird kein require_once für das langsame Backend verwendet
  412. (nur für eigene Backends nützlich)
  413. </entry>
  414. </row>
  415. <row>
  416. <entry><emphasis>fast_backend_autoload</emphasis></entry>
  417. <entry><type>Boolean</type></entry>
  418. <entry><constant>FALSE</constant></entry>
  419. <entry>
  420. Wenn true, wird kein require_once für das schnelle Backend verwendet
  421. (nur für eigene Backends nützlich)
  422. </entry>
  423. </row>
  424. <row>
  425. <entry><emphasis>auto_refresh_fast_cache</emphasis></entry>
  426. <entry><type>Boolean</type></entry>
  427. <entry><constant>TRUE</constant></entry>
  428. <entry>
  429. Wenn true, wird der schnelle Cache automatisch refresht wenn ein Cache
  430. Eintrag getroffen wird
  431. </entry>
  432. </row>
  433. <row>
  434. <entry><emphasis>stats_update_factor</emphasis></entry>
  435. <entry><type>Integer</type></entry>
  436. <entry>10</entry>
  437. <entry>
  438. Ausschalten / Feintunen der Berechnung des Füll-Prozentsatzes des
  439. schnellen Backends (wenn ein Eintrag in den Cache gespeichert wird,
  440. die Berechnung des Füll-Prozentsatzes des schnellen Backends zufällig
  441. 1 mal bei x Cache Schreibvorgängen)
  442. </entry>
  443. </row>
  444. </tbody>
  445. </tgroup>
  446. </table>
  447. </sect2>
  448. <sect2 id="zend.cache.backends.zendserver">
  449. <title>Zend_Cache_Backend_ZendServer_Disk und Zend_Cache_Backend_ZendServer_ShMem</title>
  450. <para>
  451. Diese Backends speichern Cacheeinträge indem Sie die Caching Funktionalitäten von <ulink
  452. url="http://www.zend.com/en/products/server/downloads-all?zfs=zf_download">Zend
  453. Server</ulink> verwenden.
  454. </para>
  455. <para>
  456. Achtung: mit diesen Backends werden für den Moment "Tags" nicht unterstützt, wegen dem
  457. "doNotTestCacheValidity=true" Argument.
  458. </para>
  459. <para>
  460. Diese Backends arbeiten nur nur in einer Zend Server Umgebung für Seiten die über
  461. HTTP(S) angefragt wurden und nicht für Kommandozeilen Ausführung.
  462. </para>
  463. <para>
  464. Es gibt keine Optionen für diese Backends.
  465. </para>
  466. </sect2>
  467. </sect1>
  468. <!--
  469. vim:se ts=4 sw=4 et:
  470. +-->