APC まとめ
APC (Alternative PHP Cache) を導入すると、PHP の実行速度が大幅に向上する。仕組みは、PHP はスクリプト言語なので実行するたびにコンパイルが行われるが、APC によって中間コードをキャッシュすることで、高速化を行っている。
導入
APC を pecl でインストールする。
CODE:
-
# yum -y install httpd httpd-devel php php-devel php-pear php-gd gcc
-
# pecl install apc
-
-
... 略
-
Build process completed successfully
-
Installing '/var/tmp/pear-build-root/install-APC-3.0.19//usr/lib/php/modules/apc.so'
-
install ok: channel://pecl.php.net/APC-3.0.19
-
You should add "extension=apc.so" to php.ini
-
-
# ll /usr/lib/php/modules/apc.so
-
-
-rwxr-xr-x 1 root root 412650 Dec 1 11:51 /usr/lib/php/modules/apc.so
APC の設定ファイルを作成する。これはパフォーマンスを重視した設定内容のため、注意する事。
CODE:
-
# cat /etc/php.d/apc.ini
-
-
; 必修項目
-
extension=apc.so ; 必修
-
-
; カスタマイズ
-
apc.shm_size=100 ; 個々の共有メモリセグメントの大きさを MB 単位で指定 (default 30)
-
apc.file_update_protection=0 ; [要注意] 新しいファイルをキャッシュするまでの遅延秒数 (default 2)
-
apc.stat=0 ; [要注意] ファイル更新を確認する (default 1)
-
-
; デフォルト値
-
apc.enabled=1 ; APC を有効にする
-
apc.shm_segments=1 ; コンパイラキャッシュのために割り当てる共有メモリセグメントの数
-
apc.optimization=0 ; [実験項目] 最適化レベル
-
apc.num_files_hint=1000 ; Web サーバで読み込まれるソースファイルの総数についてのヒント
-
apc.user_entries_hint=4096 ; apc.num_files_hint と同様に、保存するユーザキャッシュ変数の数についてのヒント
-
apc.ttl=0 ; キャッシュされているエントリが、他のエントリに割り当てられるまでスロットに残っていることの可能な秒数
-
apc.user_ttl=0 ; ユーザキャッシュエントリが、 他のエントリに割り当てられるまでスロットに残っていることの可能な秒数
-
apc.gc_ttl=3600 ; キャッシュエントリがガベージコレクションのリストに残り続ける秒数
-
apc.cache_by_default=1 ; OFF にすると、次項のフィルタリストに一致したファイルのみをキャッシュできる
-
apc.filters=NULL ; フィルタリスト
-
apc.mmap_file_mask=NULL ; mktemp 形式のファイルマスクを指定
-
apc.slam_defense=0 ; [非推奨] ファイルをキャッシュせずに利用する割合
-
apc.enable_cli=0 ; デバッグモード
-
apc.max_file_size=1M ; この値よも大きなサイズのファイルは、キャッシュしない (default 1M)
-
apc.write_lock=1 ; ひとつのプロセスのみが未キャッシュのスクリプトをコンパイルする
-
apc.report_autofilter=0 ; バインド時の問題によりキャッシュから自動的に除外されたスクリプトを記録
-
apc.include_once_override=0 ; include_once() および require_once() を最適化し、コストの高いシステムコールの使用を避ける
-
apc.rfc1867=0 ; PHP 5.2.0 以降
-
apc.rfc1867_prefix=upload_ ; PHP 5.2.0 以降
-
apc.rfc1867_name=APC_UPLOAD_PROGRESS ; PHP 5.2.0 以降
-
apc.rfc1867_freq=0 ; PHP 5.2.0 以降
-
apc.localcache=0 ; ロックが不要なローカルプロセスのシャドウキャッシュを行う
-
apc.localcache.size=512 ; ローカルプロセスのシャドウキャッシュの大きさ
-
apc.coredump_unmap=0 ; [実験項目] シグナルの発生時にコアファイルを書き出せる
-
apc.stat_ctime=0 ; ctime による検証を行う
APC のステータスを Web 上から確認するスクリプトへのリンクを張る。また、デフォルト値の状態だと認証できない為、認証情報を修正する。
CODE:
-
# ln -s /usr/share/pear/apc.php /var/www/html/apcinfo.php
-
# vi /var/www/html/apcinfo.php
-
-
defaults('ADMIN_USERNAME','********'); // Admin Username
-
defaults('ADMIN_PASSWORD','********'); // Admin Password - CHANGE THIS TO ENABLE!!!
APC を実行し、設定内容を確認する。
CODE:
-
# service httpd restart
-
# echo "<?php phpinfo(); ?>" /var/www/html/phpinfo.php
-
# php /var/www/html/phpinfo.php | grep apc
-
-
additional .ini files parsed => /etc/php.d/apc.ini,
-
apc
-
apc.cache_by_default => On => On
-
apc.coredump_unmap => Off => Off
-
apc.enable_cli => Off => Off
-
apc.enabled => On => On
-
apc.file_update_protection => 0 => 0
-
apc.filters => no value => no value
-
apc.gc_ttl => 3600 => 3600
-
apc.include_once_override => Off => Off
-
apc.max_file_size => 1M => 1M
-
apc.mmap_file_mask => no value => no value
-
apc.num_files_hint => 1000 => 1000
-
apc.report_autofilter => Off => Off
-
apc.shm_segments => 1 => 1
-
apc.shm_size => 100 => 100
-
apc.slam_defense => 0 => 0
-
apc.stat => Off => Off
-
apc.stat_ctime => Off => Off
-
apc.ttl => 0 => 0
-
apc.user_entries_hint => 4096 => 4096
-
apc.user_ttl => 0 => 0
-
apc.write_lock => On => On
http://IP/apcinfo.php に接続し、設定した認証情報で表示できるか確かめる。また、APC の設定項目で apc.stat=0 を行っているため、PHP スクリプトを編集した場合も、APC による編集前のキャッシュが実行される。そのため、ファイル更新を行うには Apache の再起動を行い、古いキャッシュを削除する必要がある。
関連文献
PHP: APC - Manual
http://www.php.net/manual/ja/book.apc.php