Zend_Cache-Theory.xml 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="zend.cache.theory">
  5. <title>キャッシュの仕組み</title>
  6. <para>
  7. <classname>Zend_Cache</classname> には、3 つのポイントがあります。まず最初は一意な ID (文字列) で、
  8. これによってキャッシュレコードを識別します。二番目は、例に含まれる
  9. <emphasis>'lifetime'</emphasis> ディレクティブです。これは、キャッシュされたリソースの
  10. 「賞味期限」を定義するものです。三番目のポイントとなるのが条件付きの実行処理で、
  11. 不要なコードを完全に読み飛ばすことで処理速度を向上させることになります。
  12. フロントエンドの主となる関数 (例えば <methodname>Zend_Cache_Core::get()</methodname>)
  13. は、キャッシュがヒットしなかった場合には常に <constant>FALSE</constant> を返すよう設計されています。
  14. そのため、キャッシュしたい (そして読み飛ばしたい) 部分を
  15. <emphasis><methodname>if()</methodname>{ ... }</emphasis> 文で囲む際に、
  16. 条件式として <classname>Zend_Cache</classname>
  17. のメソッド自身を使用できるようになっています。
  18. このブロックの最後では、出力内容を
  19. (例えば <methodname>Zend_Cache_Core::save()</methodname> などで)
  20. 保存する必要があります。
  21. </para>
  22. <note>
  23. <para>
  24. 条件付きの実行処理を必ず記述しなければならないわけではありません。
  25. フロントエンドの種類によっては (例えば <emphasis>Function</emphasis> など)、
  26. すべてのロジックがフロントエンドの中で実装されています。
  27. </para>
  28. </note>
  29. <note>
  30. <para>
  31. 'Cache hit (キャッシュにヒットした)' とは、キャッシュレコードが見つかり、
  32. かつそのレコードが 'fresh (新鮮)' (言い換えると、まだ有効期限が切れていない)
  33. 状態であることを表す言葉です。'Cache miss (キャッシュが見つからなかった)'
  34. はその正反対です。キャッシュが見つからなかった場合は、
  35. データを (通常どおりに) 作成し、それをキャッシュしなければなりません。
  36. 一方、キャッシュにヒットした場合は、
  37. バックエンドが自動的にキャッシュレコードを取得してくれます。
  38. </para>
  39. </note>
  40. <sect2 id="zend.cache.factory">
  41. <title>Zend_Cache ファクトリメソッド</title>
  42. <para>
  43. 使用可能な <classname>Zend_Cache</classname> フロントエンドのインスタンスを作成する方法を、
  44. 以下の例で示します。
  45. </para>
  46. <programlisting language="php"><![CDATA[
  47. // バックエンドを選びます (例えば 'File' や 'Sqlite'...)
  48. $backendName = '[...]';
  49. // フロントエンドを選びます (例えば 'Core'、'Output'、'Page'...)
  50. $frontendName = '[...]';
  51. // 選択したフロントエンド用のオプションを配列に設定します
  52. $frontendOptions = array([...]);
  53. // 選択したバックエンド用のオプションを配列に設定します
  54. $backendOptions = array([...]);
  55. // インスタンスを作成します
  56. // (もちろん、最後の 2 つの引数は必須ではありません)
  57. $cache = Zend_Cache::factory($frontendName,
  58. $backendName,
  59. $frontendOptions,
  60. $backendOptions);
  61. ]]></programlisting>
  62. <para>
  63. これ以降のドキュメントでは、<varname>$cache</varname>
  64. の中身が有効なフロントエンドになっているものとします。また、
  65. 選択したバックエンドにパラメータを渡す方法は理解できているものとします。
  66. </para>
  67. <note>
  68. <para>
  69. 常に <methodname>Zend_Cache::factory()</methodname> を使用してフロントエンドの
  70. インスタンスを作成するようにしてください。フロントエンドやバックエンドを
  71. 自前で作成しようとしても、期待通りには動作しないでしょう。
  72. </para>
  73. </note>
  74. </sect2>
  75. <sect2 id="zend.cache.tags">
  76. <title>レコードのタグ付け</title>
  77. <para>
  78. タグは、キャッシュレコードを分類するための仕組みです。
  79. <methodname>save()</methodname> メソッドでキャッシュを保存する際に、
  80. 適用するタグを配列で指定できます。これを使用すると、
  81. 指定したタグが設定されているキャッシュレコードのみを削除するといったことが可能となります。
  82. </para>
  83. <programlisting language="php"><![CDATA[
  84. $cache->save($huge_data, 'myUniqueID', array('tagA', 'tagB', 'tagC'));
  85. ]]></programlisting>
  86. <note>
  87. <para>
  88. <methodname>save()</methodname> メソッドには、オプションの第四引数
  89. <varname>$specificLifetime</varname> を指定できることに注意しましょう
  90. (<constant>FALSE</constant> 以外を指定することで、このキャッシュレコードの有効期限を特定の値に設定できます)。
  91. </para>
  92. </note>
  93. </sect2>
  94. <sect2 id="zend.cache.clean">
  95. <title>キャッシュの削除</title>
  96. <para>
  97. 特定のキャッシュ ID を削除/無効化するには、<methodname>remove()</methodname>
  98. メソッドを使用します。
  99. </para>
  100. <programlisting language="php"><![CDATA[
  101. $cache->remove('削除するID');
  102. ]]></programlisting>
  103. <para>
  104. 一回の操作で複数のキャッシュ ID を削除/無効化するには、<methodname>clean()</methodname>
  105. メソッドを使用します。例えば、すべてのキャッシュレコードを削除するには次のようにします。
  106. </para>
  107. <programlisting language="php"><![CDATA[// すべてのレコードを削除します
  108. $cache->clean(Zend_Cache::CLEANING_MODE_ALL);
  109. // 有効期限切れのレコードのみ削除します
  110. $cache->clean(Zend_Cache::CLEANING_MODE_OLD);
  111. ]]></programlisting>
  112. <para>
  113. タグ 'tagA' および 'tagC' に該当するキャッシュエントリを削除するには、このようにします。
  114. </para>
  115. <programlisting language="php"><![CDATA[
  116. $cache->clean(
  117. Zend_Cache::CLEANING_MODE_MATCHING_TAG,
  118. array('tagA', 'tagC')
  119. );
  120. ]]></programlisting>
  121. <para>
  122. タグ 'tagA' にも 'tagC' にも該当しないキャッシュエントリを削除するには、このようにします。
  123. </para>
  124. <programlisting language="php"><![CDATA[
  125. $cache->clean(
  126. Zend_Cache::CLEANING_MODE_NOT_MATCHING_TAG,
  127. array('tagA', 'tagC')
  128. );
  129. ]]></programlisting>
  130. <para>
  131. タグ 'tagA' または 'tagC' に該当するキャッシュエントリを削除するには、このようにします。
  132. </para>
  133. <programlisting language="php"><![CDATA[
  134. $cache->clean(
  135. Zend_Cache::CLEANING_MODE_MATCHING_ANY_TAG,
  136. array('tagA', 'tagC')
  137. );
  138. ]]></programlisting>
  139. <para>
  140. 削除モードとして指定可能な値は <constant>CLEANING_MODE_ALL</constant>、<constant>CLEANING_MODE_OLD</constant>、
  141. <constant>CLEANING_MODE_MATCHING_TAG</constant>、<constant>CLEANING_MODE_NOT_MATCHING_TAG</constant> および
  142. <constant>CLEANING_MODE_MATCHING_ANY_TAG</constant> です。
  143. 後者は、その名が示すとおり、タグの配列と組み合わせて使用します。
  144. </para>
  145. </sect2>
  146. </sect1>
  147. <!--
  148. vim:se ts=4 sw=4 et:
  149. -->