Zend_Cache-Backends.xml 24 KB

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