I. APC インストール構成
私の記事を参照してください
II. php.ini設定項目[APC]セクションの詳細説明
[APC]
; 代替 PHP キャッシュは PHP 中間コードのキャッシュと最適化に使用されます
apc.cache_by_default = オン
;シス
; すべてのファイルに対してデフォルトでバッファリングを有効にするかどうか。
; オフに設定し、プラス記号で始まる apc.filters ディレクティブと一緒に使用すると、ファイルはフィルターに一致する場合にのみキャッシュされます。
apc.enable_cli = オフ
;シス
; cli バージョンで apc 機能を有効にするかどうかは、テストとデバッグの目的でのみこのディレクティブをオンにします。
apc.enabled = オン
; apc を有効にするかどうか。apc が php に静的にコンパイルされており、それを無効にしたい場合は、これが唯一の方法です。
apc.file_update_protection = 2
;シス
; 実行中のサーバー上のファイルを変更する場合は、アトミック操作を実行する必要があります。
; つまり、最初に一時ファイルに書き込み、次にファイルの名前を最終的な名前に変更 (mv) します。
; テキスト エディターや cp や tar などのプログラムはこのように動作しないため、不完全なファイルがバッファリングされる可能性があります。
; デフォルト値 2 は、ファイルにアクセスするときに、変更時間がアクセス時間から 2 秒未満であることが判明した場合、バッファリングは実行されないことを意味します。
; 運が悪い訪問者は破損したコンテンツを受け取る可能性がありますが、その悪影響はキャッシュによって増幅されません。
; すべての更新操作がアトミックであることを確認できる場合は、0 を指定してこの機能をオフにすることができます。
; IO 操作が多いためにシステムの更新が遅い場合は、この値を増やす必要がある場合があります。
apc.filters =
;シス
; POSIX 拡張正規表現のカンマ区切りのリスト。
; ソース ファイル名がいずれかのパターンに一致する場合、ファイルはキャッシュされません。
; マッチングに使用されるファイル名は、絶対パスではなく、include/require に渡されるファイル名であることに注意してください。
; 正規表現の最初の文字が「+」の場合、その正規表現に一致するファイルがキャッシュされることを意味します。
; 最初の文字が「-」の場合、一致するものはキャッシュされません。 「-」はデフォルト値であり省略可能です。
apc.ttl = 0
;シス
; キャッシュ エントリがバッファ内に存在できる秒数。 0 はタイムアウトしないことを意味します。推奨値は7200~36000です。
; 0 に設定すると、バッファが古いキャッシュ エントリでいっぱいになり、新しいエントリがキャッシュされなくなる可能性があります。
apc.user_ttl = 0
;シス
; apc.ttl と似ていますが、各ユーザーの推奨値は 7200 ~ 36000 です。
; 0 に設定すると、バッファが古いキャッシュ エントリでいっぱいになり、新しいエントリがキャッシュされなくなる可能性があります。
apc.gc_ttl = 3600
;シス
; キャッシュ エントリがガベージ コレクション テーブルに存在できる秒数。
; この値は、キャッシュされたソース ファイルの実行中にサーバー プロセスがクラッシュした場合でも安全対策を提供します。
; ソース ファイルが変更されている場合、古いバージョンに割り当てられたメモリは、この ttl 値に達するまで再利用されません。
; この機能を無効にするには、0 に設定します。
apc.include_once_override = オフ
;シス
; 現在、このコマンドに関するドキュメントはありません。http://pecl.php.net/bugs/bug.php?id=8754
を参照してください。; 予期しない結果が生じる可能性があるため、オフにしておいてください。
apc.max_file_size = 1m
;シス
; このサイズを超えるファイルがキャッシュされないようにします。
apc.mmap_file_mask =
;シス
; --enable-mmap (デフォルトで有効) を使用して mmap サポートが apc 用にコンパイルされている場合、
; ここでの値は、mmap モジュールに渡される mktemp スタイルのファイル マスクです (推奨値は「/tmp/apc.xxxxxx」です)。
; このマスクは、メモリ マップ領域をファイル バックアップするか共有メモリ バックアップするかを決定するために使用されます。
; 直接ファイルバックアップメモリマッピングの場合は、「/tmp/apc.xxxxxx」(正確には 6 つの x)に設定します。
; posix スタイルの shm_open/mmap を使用するには、「/apc.shm.xxxxxx」に設定する必要があります。
; 「/dev/zero」に設定して、匿名でマップされたメモリにカーネルの「/dev/zero」インターフェイスを使用することもできます。
; このディレクティブを定義しないと、匿名マッピングの使用が強制されます。
apc.num_files_hint = 1000
;シス
; Web サーバーに含めたりリクエストしたりできるさまざまなソース ファイルのおおよその数 (推奨値は 1024 ~ 4096)。
; よくわからない場合は、0 に設定してください。この設定は主に、数千のソース ファイルを含むサイトに使用されます。
apc.最適化 = 0
; 最適化レベル (推奨値は 0)。
; 正の整数値はオプティマイザーを有効にし、値が大きいほどより積極的な最適化を使用します。
; 値を大きくすると、速度の改善が非常に限定される可能性がありますが、現在は実験段階です。
apc.report_autofilter = オフ
;シス
; 早期/遅延バインディングの理由により自動的にキャッシュされないすべてのスクリプトを記録するかどうか。
apc.shm_segments = 1
;シス
; コンパイラ バッファに割り当てられる共有メモリ ブロックの数 (推奨値は 1)。
; apc が共有メモリを使い果たし、apc.shm_size ディレクティブがシステムで許容される最大値に設定されている場合、
; この値を増やしてみてください。
apc.shm_size = 30
;シス
; 各共有メモリ ブロックのサイズ (MB 単位、推奨値は 128 ~ 256)。
; 一部のシステム (ほとんどの BSD バリアントを含む) のデフォルトの共有メモリ ブロック サイズは非常に小さいです。
apc.slam_defense = 0
;sys (このコマンドの使用には反対です。apc.write_lock コマンドを使用することをお勧めします)
; 非常に負荷の高いサーバーでは、サービスの開始やファイルの変更など、
; 複数のプロセスが同時にファイルをキャッシュしようとするため、競合状態が発生する可能性があります。
; このディレクティブは、キャッシュされていないファイルを処理するときにプロセスがキャッシュ手順をスキップする割合を設定するために使用されます。
; たとえば、これを 75 に設定すると、キャッシュされていないファイルが見つかった場合に 75% の確率でキャッシュされないため、衝突の可能性が低くなります。
; この機能を無効にするには、0 に設定することをお勧めします。
apc.stat = オン
;シス
; スクリプトの更新チェックを有効にするかどうか。
; このディレクティブの値を変更する場合は十分に注意してください。
; デフォルト値 on は、スクリプトがリクエストされるたびに apc が更新されたかどうかをチェックすることを意味します。
; 更新された場合は、コンパイルされたコンテンツを自動的に再コンパイルしてキャッシュします。ただし、これを行うとパフォーマンスに悪影響が生じます。; オフに設定すると、チェックは実行されないため、パフォーマンスが大幅に向上します。
; ただし、更新されたコンテンツを有効にするには、Web サーバーを再起動する必要があります。
; このディレクティブは include/require ファイルにも有効です。ただし、注意してください
; 相対パスを使用する場合、apc は include/require ごとにファイルの場所を確認する必要があります。
; 絶対パスを使用するとチェックがスキップされる可能性があるため、include/require 操作には絶対パスを使用することをお勧めします。
apc.user_entries_hint = 100
;シス
; num_files_hint ディレクティブに似ていますが、ユーザーごとに異なります。
; よくわからない場合は、0 に設定してください。
apc.write_lock = オン
;シス
; 書き込みロックを有効にするかどうか。
; 非常に負荷の高いサーバーでは、サービスの開始やファイルの変更など、
; 複数のプロセスが同時にファイルをキャッシュしようとするため、競合状態が発生する可能性があります。
; 競合状態を回避するには、このディレクティブを有効にします。
apc.rfc1867 = オフ
;シス
; このディレクティブをオンにした後、ファイル フィールドの直前に apc_upload_progress フィールドを含むアップロード ファイルごとに、
; apc は、upload_ のユーザー キャッシュ エントリ (apc_upload_progress フィールドの値) を自動的に作成します。
III. 機能:
apc_cache_info - APC のデータストアからキャッシュされた情報 (およびメタデータ) を取得します
apc_clear_cache - APC キャッシュをクリアします
apc_define_constants - 後で取得および一括定義するための定数のセットを定義します
apc_delete - 保存された変数をキャッシュから削除します
apc_fetch - 保存された変数をキャッシュからフェッチします
apc_load_constants - キャッシュから一連の定数をロードします
apc_sma_info - APC の共有メモリ割り当て情報を取得します
apc_store - データストアに変数をキャッシュします
apc の使用法は比較的単純で、以下に示す機能がいくつかあるだけです。
apc_cache_info () はキャッシュ情報を返します
apc_clear_cache() は、APC キャッシュの内容をクリアします。
デフォルト (パラメータなし) では、システム キャッシュのみがクリアされます。ユーザー キャッシュをクリアするには、「user」パラメータが必要です。
apc_define_constants (string key, array constants [, bool case_sensitive]) 配列定数を定数としてキャッシュに追加します。
apc_load_constants (文字列キー)。
定数キャッシュを削除します。
apc_store (文字列キー、混合変数 [, int ttl] )。
データをキャッシュに保存します。
apc_fetch(文字列キー)。
apc_store によって保存されたキャッシュ コンテンツを取得します
apc_delete (文字列キー)。
apc_store で保存したコンテンツを削除します。
IV.APC管理
pecl.php.net に移動して、apc ソース コード パッケージをダウンロードします。apc.php があるので、それを Web サーバーがアクセスできる場所にコピーし、参照してアクセスします。
管理インターフェースの機能には以下が含まれます:
1. データを更新します
2. ホスト統計を表示する
3. システムキャッシュエントリ
4. ユーザーキャッシュエントリ
5. バージョン確認
セクション 4 のこのツールに注目してください。非常に便利です