4.4. Zend_Cache のバックエンド

4.4.1. Zend_Cache_Backend_File

このバックエンドは、キャッシュレコードを (指定したディレクトリの) ファイルに保存します。

使用可能なオプションは次のとおりです。

表 4.6. 使用可能なオプション

オプション データ型 デフォルト値 説明
cache_dir string '/tmp/' キャッシュファイルを書き込むディレクトリ。
file_locking boolean true ファイルロックを有効/無効にします。 不慮の事故でキャッシュが破壊されることを防げますが、 マルチスレッドなウェブサーバ環境や NFS ファイルシステム上では役に立ちません。
read_control boolean true 読み込み制御を有効/無効にします。有効にすると キャッシュファイルに制御キーが埋め込まれます。 キャッシュの読み込み後、計算した結果とキャッシュのキーを比較します。
read_control_type string 'crc32' 読み込み制御の方式 (読み込み制御が有効な場合にのみ使用します)。 使用可能な値は 'md5' (一番安全だが、最も遅い)、 'crc32' (安全性には劣るが、より高速。悪くない選択肢です)、 'strlen' (最も高速。長さのみをチェックします) のいずれかです。
hashed_directory_level int 0 ディレクトリ構造のレベルを指定します。0 は "ディレクトリ階層を作らない"、 1 は "一段階のサブディレクトリを作る"、2 は "二段階の……" を意味します。 何千ものキャッシュファイルを使用する場合にのみ、 このオプションによる高速化を実感できるでしょう。 適切な設定値を決めるには、実際にベンチマークを取得するしかありません。 たいていの場合は 1 または 2 でよいでしょう。
hashed_directory_umask int 0700 ディレクトリ構造の umask を指定します。
file_name_prefix string 'zend_cache' キャッシュファイルのプレフィックスを設定します。 このオプションを設定する際には十分注意しましょう。 あまりにもありふれた値をシステムのキャッシュディレクトリ (/tmp など) で使用すると、 キャッシュの削除の際に余計なものまで削除されてしまうはめになります。

4.4.2. Zend_Cache_Backend_Sqlite

このバックエンドは、キャッシュレコードを SQLite データベースに保存します。

使用可能なオプションは次のとおりです。

表 4.7. 使用可能なオプション

オプション データ型 デフォルト値 説明
cache_db_complete_path (必須) string null SQLite データベースへの (ファイル名も含めた) フルパス。
automatic_vacuum_factor int 10 自動バキューム処理の設定を行います。 自動バキューム処理とは、clean() や delete() がコールされた際に自動的にデータベースの断片化解消を行う (そしてサイズを縮小する) ことです。 0 を指定すると、自動バキュームを行いません。 1 を指定すると (delete() や clean() がコールされると) そのたびにバキュームを行います。 x (1 より大きな整数) を指定すると、 clean() や delete() が x 回コールされるたびに 一回の頻度でランダムに自動バキュームを行います。

4.4.3. Zend_Cache_Backend_Memcached

このバックエンドは、キャッシュレコードを memcached サーバに保存します。 memcached は、 高性能な分散メモリオブジェクトキャッシュシステムです。このバックエンドを使用するには、 memcached デーモンおよび memcache PECL 拡張モジュール が必要です。

注意: このバックエンドでは、今のところ "タグ" がサポートされていません。 また、引数 "doNotTestCacheValidity=true" もサポートされていません。

使用可能なオプションは次のとおりです。

表 4.8. 使用可能なオプション

オプション データ型 デフォルト値 説明
servers array array(array('host' => 'localhost','port' => 11211, 'persistent' => true)) memcached サーバの配列です。各 memcached サーバの情報は、 以下のような連想配列で指定します。 'host' => (string) : memcached サーバのサーバ名 'port' => (int) : memcached サーバのポート番号 'persistent' => (bool) : この memcached サーバに対して持続的な接続を使用するかどうか
compression boolean false その場での圧縮処理を行いたい場合に true を指定します。

4.4.4. Zend_Cache_Backend_APC

このバックエンドは、キャッシュレコードを共有メモリに保存する際に APC (Alternative PHP Cache) 拡張モジュールを使用します (当然、このバックエンドを使用するにはこの拡張モジュールが必要です)。

注意: このバックエンドでは、今のところ "タグ" がサポートされていません。 また、引数 "doNotTestCacheValidity=true" もサポートされていません。

このバックエンドではオプションを使用しません。

4.4.5. Zend_Cache_Backend_ZendPlatform

このバックエンドは、Zend Platform 製品のコンテンツキャッシング API を使用します。当然、このバックエンドを使用するには Zend Platform をインストールする必要があります。

このバックエンドはタグをサポートしています。しかし、 クリーニングモード CLEANING_MODE_NOT_MATCHING_TAG はサポートしていません。

このバックエンドではオプションを使用しません。