<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/refs.basic.php.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ja',
  ),
  'this' => 
  array (
    0 => 'book.wincache.php',
    1 => 'WinCache',
    2 => 'PHP 用の Windows キャッシュ',
  ),
  'up' => 
  array (
    0 => 'refs.basic.php.php',
    1 => 'PHP の振る舞いの変更',
  ),
  'prev' => 
  array (
    0 => 'function.uopz-unset-return.php',
    1 => 'uopz_unset_return',
  ),
  'next' => 
  array (
    0 => 'wincache.setup.php',
    1 => 'インストール/設定',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ja',
    'path' => 'reference/wincache/book.xml',
  ),
  'history' => 
  array (
  ),
  'extra_header_links' => 
  array (
    'rel' => 'alternate',
    'href' => '/manual/en/feeds/book.wincache.atom',
    'type' => 'application/atom+xml',
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="book.wincache" class="book">
 
 <h1 class="title">PHP 用の Windows キャッシュ</h1>
 

 <div id="intro.wincache" class="preface">
  <h1 class="title">はじめに</h1>
  <p class="para">
   Windows Cache Extension for PHP は、PHP のアクセラレータです。
   Windows および Windows サーバー上での PHP アプリケーションの動作速度を向上させます。
   Windows Cache Extension for PHP を有効にして PHP エンジンに読み込むと、
   PHP アプリケーションのコードに一切手を加えずに恩恵を受けることができます。
  </p>
  <p class="para">
   Windows Cache Extension には 5 種類のキャッシュが含まれています。
   それぞれのキャッシュ型の目的と利点を以下にまとめました。
  </p>
  <ul class="itemizedlist">
   <li class="listitem">
    <p class="para">
     <em>PHP Opcode キャッシュ</em> - PHP はスクリプト処理エンジンです。
     テキストや PHP の命令からなるデータストリームを入力として読み込み、
     別の形式 (通常は HTML 形式) のデータストリームを生成します。
     つまり、ウェブクライアントからのリクエストを受け取るたびに、
     PHP エンジンが PHP スクリプトの読み込みとパース、コンパイルそして実行を行っているわけです。
     読み込み、パースそしてコンパイルはウェブサーバーの CPU やファイルシステムに負荷をかけ、
     PHP ウェブアプリケーション全体のパフォーマンスに影響を及ぼします。
     PHP バイトコード (opcode) キャッシュを使うと、コンパイル済みのスクリプトのバイトコードを共有メモリに置きます。
     同じスクリプトが再びリクエストされたときには、PHP エンジンはこのバイトコードを再利用します。
    </p>
    <p class="para">
     opcode キャッシングのサポートは、<code class="literal">Wincache 2.0.0</code> で削除されました。
     opcache を所有したいすべてのユーザーは、PHP に含まれる
     <a href="book.opcache.php" class="link">OPcache</a> 拡張を使用すべきです。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     <em>ファイルキャッシュ</em> - PHP opcode のキャッシュを有効にしたとしても、
     PHP エンジンはファイルシステム上のスクリプトファイルにアクセスしなければなりません。
     PHP のスクリプトをリモートの UNC ファイル共有に置いている場合には、
     ファイル操作はパフォーマンス面での深刻なオーバーヘッドとなります。
     Windows Cache Extension for PHP にはファイルキャッシュ機能が組み込まれており、
     PHP スクリプトファイルの内容を共有メモリに格納することができます。
     これにより、PHP エンジンからのファイルシステム操作の量を減らすことができます。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     <em>ファイルパス解決キャッシュ</em> - PHP スクリプトでは、
     相対ファイルパス指定によるファイル操作やインクルードが頻繁に発生します。
     このとき、PHP エンジンは相対パスを絶対パスに変換しなければなりません。
     PHP のアプリケーションで、相対パス指定した PHP ファイルへのアクセスが多くなると、
     パスの解決がアプリケーションのパフォーマンスに大きな影響を及ぼします。
     Windows Cache Extension for PHP のファイルパス解決キャッシュを使うと、
     相対パスと絶対パスの対応を保存しておくことができます。
     これにより、PHP エンジンが行わなければならないパス解決の量を減らすことができます。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     <em>ユーザーキャッシュ (バージョン 1.1.0 以降で使用可能)</em> -
     ユーザーキャッシュ API を使うと、PHP スクリプトから共有メモリキャッシュを使うことができます。
     PHP のオブジェクトや変数をユーザーキャッシュに格納し、
     別のリクエストでそれを再利用することができるのです。
     これは PHP スクリプトのパフォーマンスを向上させ、
     複数の PHP プロセスからのデータへのアクセスを共有することができます。
    </p>
   </li>
   <li class="listitem">
    <p class="para">
     <em>セッションハンドラ (バージョン 1.1.0 以降で使用可能)</em> -
     WinCache セッションハンドラを使うと、PHP のセッションデータを共有メモリキャッシュに置くことができます。
     セッションデータの読み書き時のファイルシステム操作が不要になり、
     大量のデータを PHP セッションに格納するときのパフォーマンスが向上します。
    </p>
   </li>
  </ul>
 </div>

 








 








 







<ul class="chunklist chunklist_book"><li><a href="wincache.setup.php">インストール/設定</a><ul class="chunklist chunklist_book chunklist_children"><li><a href="wincache.requirements.php">要件</a></li><li><a href="wincache.installation.php">インストール手順</a></li><li><a href="wincache.configuration.php">実行時設定</a></li><li><a href="wincache.stats.php">WinCache 統計スクリプト</a></li><li><a href="wincache.sessionhandler.php">WinCache セッションハンドラ</a></li><li><a href="wincache.reroutes.php">WinCache 関数への切り替え</a></li></ul></li><li><a href="ref.wincache.php">WinCache 関数</a><ul class="chunklist chunklist_book chunklist_children"><li><a href="function.wincache-fcache-fileinfo.php">wincache_fcache_fileinfo</a> — ファイルキャッシュにキャッシュされたファイルについての情報を取得する</li><li><a href="function.wincache-fcache-meminfo.php">wincache_fcache_meminfo</a> — ファイルキャッシュのメモリ使用状況についての情報を取得する</li><li><a href="function.wincache-lock.php">wincache_lock</a> — 指定したキーで排他ロックを確保する</li><li><a href="function.wincache-ocache-fileinfo.php">wincache_ocache_fileinfo</a> — opcode キャッシュにキャッシュされたファイルについての情報を取得する</li><li><a href="function.wincache-ocache-meminfo.php">wincache_ocache_meminfo</a> — opcode キャッシュのメモリ使用状況についての情報を取得する</li><li><a href="function.wincache-refresh-if-changed.php">wincache_refresh_if_changed</a> — キャッシュされたファイルのキャッシュエントリをリフレッシュする</li><li><a href="function.wincache-rplist-fileinfo.php">wincache_rplist_fileinfo</a> — ファイルパス解決キャッシュについての情報を取得する</li><li><a href="function.wincache-rplist-meminfo.php">wincache_rplist_meminfo</a> — ファイルパス解決キャッシュのメモリ使用状況についての情報を取得する</li><li><a href="function.wincache-scache-info.php">wincache_scache_info</a> — セッションキャッシュにキャッシュされたファイルについての情報を取得する</li><li><a href="function.wincache-scache-meminfo.php">wincache_scache_meminfo</a> — セッションキャッシュのメモリ使用状況についての情報を取得する</li><li><a href="function.wincache-ucache-add.php">wincache_ucache_add</a> — 変数が既にキャッシュに存在しない場合にのみ変数をユーザーキャッシュに追加する</li><li><a href="function.wincache-ucache-cas.php">wincache_ucache_cas</a> — 変数を古い値と比較して新しい値を代入する</li><li><a href="function.wincache-ucache-clear.php">wincache_ucache_clear</a> — ユーザーキャッシュの中身全体を削除する</li><li><a href="function.wincache-ucache-dec.php">wincache_ucache_dec</a> — キーに関連づけられた値を減少させる</li><li><a href="function.wincache-ucache-delete.php">wincache_ucache_delete</a> — 変数をユーザーキャッシュから削除する</li><li><a href="function.wincache-ucache-exists.php">wincache_ucache_exists</a> — 変数がユーザーキャッシュに存在するかどうかを調べる</li><li><a href="function.wincache-ucache-get.php">wincache_ucache_get</a> — ユーザーキャッシュに格納された変数を取得する</li><li><a href="function.wincache-ucache-inc.php">wincache_ucache_inc</a> — キーに関連づけられた値を増加させる</li><li><a href="function.wincache-ucache-info.php">wincache_ucache_info</a> — ユーザーキャッシュにキャッシュされたファイルについての情報を取得する</li><li><a href="function.wincache-ucache-meminfo.php">wincache_ucache_meminfo</a> — ユーザーキャッシュのメモリ使用状況についての情報を取得する</li><li><a href="function.wincache-ucache-set.php">wincache_ucache_set</a> — 変数をユーザーキャッシュに追加し、変数が既にキャッシュに存在する場合はそれを上書きする</li><li><a href="function.wincache-unlock.php">wincache_unlock</a> — 指定したキーの排他ロックを解放する</li></ul></li><li><a href="wincache.win32build.php">Windows でのビルド</a><ul class="chunklist chunklist_book chunklist_children"><li><a href="wincache.win32build.prereq.php">要件</a></li><li><a href="wincache.win32build.building.php">コンパイルおよびビルド</a></li><li><a href="wincache.win32build.verify.php">ビルドの検証</a></li></ul></li></ul></div><?php manual_footer($setup); ?>