APCがphp 5.4リリースと一致するように更新されたようではありません(当初計画されていたように、PHPコアにAPCが含まれていたと思います)。
現在のAPCがphp 5.4以降で動作するかどうかについて、明確な答えを見つけることができないようです。私はなんとかphp 5.4のUbuntuパッケージを見つけましたが、php-apcパッケージがインストールされません。
APCがphp 5.4リリースと一致するように更新されたようではありません(当初計画されていたように、PHPコアにAPCが含まれていたと思います)。
現在のAPCがphp 5.4以降で動作するかどうかについて、明確な答えを見つけることができないようです。私はなんとかphp 5.4のUbuntuパッケージを見つけましたが、php-apcパッケージがインストールされません。
回答:
2013年3月21日、「Zend OPCache」を含むPHP 5.5ベータ1がリリースされました。これは、PHPコアに含まれているため、今後APCの代わりになるようであり、新しいコアごとに維持する必要があります。リリース。
オペコードキャッシングをAPCに依存している人には個人的に、今後の組み込みのオペコードキャッシュでコードをテストし、発生した問題をフィードバックして安定した最終リリースを確保するようにアドバイスします。
これがAPCの将来にとって何を意味するのかはわかりません。
これは、開発者が完全に安定しているとは考えていないことを意味します。現在のSVNリリースでは多くの人がまったく問題を経験していませんが、特定の構成または高負荷の人からのエッジケースの奇妙なレポートがまだあります。
運用環境で使用するすべてのものと同様に、開発環境または運用前環境でリリース(ベータ版または安定版)を最初に徹底的にテストしてください。これには負荷テストも含まれます。
3.1.13リリースの時点で、SVNリポジトリへのコミットが多少遅くなり、バグリストに最近の多くの追加がありません。あなたがそうするものを作りなさい。
2012年12月10日21:05、ラスムスラードルフは次のように書いています。
APCは5.4の時点であり、5.3の場合よりも多くのエッジケースはないと思います。どちらも完璧ではありませんが、ほとんどのサイトにとって十分に近いです。
C / gdbのスキルがあり、ある程度の自由時間がある人は、バグリストを調べて何か修正できるかどうか、または私たち全員が信頼しているこの無料のオープンソース製品を改善できるかどうかを確認するように求められます。
代替ソリューションが存在し、ウィキペディアはPHPアクセラレータのリストを提供しています。
2013年2月13日、Zeev SuraskiはZend Optimizer +ソースコードの提供を発表しました。
次のメジャーバージョン(5.5以降のバージョン)では、Zend Optimizer +をPHPコアに統合することについてかなり長い議論がありました。その場合は、事前にZend Optimizer +に慣れることをお勧めします。
APC 3.1.14は、発見されたがまだ追跡されていないいくつかの深刻なメモリ問題のためにPECLダウンロードから削除されました。
すでに3.1.14を使用している場合は、3.1.15がリリースされるまでダウングレードすることをお勧めします。これはまだベータ版です。使用している場合は、自己責任で使用してください。
2013-01-02:
APC 3.1.14が利用可能になり、PHP 5.5との互換性が追加されるだけでなく、他の多数のバグも解決されます。
まだベータ版
2012-09-03:
APC 3.1.13が利用可能になり、多数のセグメンテーション違反が修正されました。
2012年8月16日:
アンAPCは3.1.12タグが作成されましたが、それでもとしてマークされているベータ版でその利用可能、APC PECLページだけでなく、更新履歴。
今回、bin_dump関連の多くのバグが修正されました。
2012-07-19:
アンAPCは3.1.11タグが作成されましたが、それでもとしてマークされているベータ版でその利用可能、APC PECLページだけでなく、更新履歴。私は関連するメーリングリストをフォローしてきましたが、彼らはまだAPCバグの修正に積極的に取り組んでいますが、それは複雑なモジュールであり、多くの人がその仕事をしているようには見えません。このリリースでは、ファイルを含める場合の厄介なstat = 0のバグが修正されています。
2012-04-11:
アンAPC 3.1.10タグが今日作成された、および3.1.10のベータリリースが上に置かれたAPC PECLページのchangelog状態:
PHP 5.4.7およびAPC 3.1.13(および2012-09-19現在のAPC SVNトランク)では、 "互換性"はありますが、特にPHPを使用している場合、負荷の高いサーバーでは安定しません。 FPMと$ GLOBALS。APCに関する開発者の議論のいくつかは、未解決のフリンジケースについて話します。
問題がまだ蔓延しているため、質問されてから6か月後にこの質問に答えています。私のスレッドのような答えがないスレッドに出会ったことが、APCを使ってPHP 5.4への飛躍を遂げた理由です。うまくいけば、これは人々がいくつかの痛みを避けるのに役立つでしょう。
トランクの最新リビジョンでは、バグが「可能性があります」と修正されているようです。PHP 5.4.0で動作するようになりました。
svn co http://svn.php.net/repository/pecl/apc/trunk/ apc-trunk
cd apc-trunk
phpize
。/構成、設定
作る
インストールする
いいえ、APC 1.3.9(および現時点ではsvnトランクも)はphp 5.4.0と互換性がありません。動作させるために何時間も費やしたためです(さまざまなsvn / phpをテストしました)。 ini設定/コンパイラフラグ/名前を付けます)。
これはとんでもないことです。APCは最も人気のあるPHP拡張機能の1つであり、8週間のPHP 5.4 RCを数週間経った後、APCを動作させる時間があると予想します。
哀れ。
さて、ここ数日試してみましたが、opcode cacherをphp 5.4で動作させる方法はありません。Xcacheはコンパイルされず、apcはキャッシュされたときに特定のクラスを認識しません。これはサイモンが話しているエラーだと思います。
トランクにいくつかの修正があると聞きましたが、最新のトランクソースも試しましたが、同じエラーが繰り返し発生します。オペコードキャッシャーなしのphp(現在利用可能なものはありません)は、本番に値しないと思います。apcの人々がこの問題をできるだけ早く修正することを願っています。
更新!!!
Xcache 2.0.0-rc1がリリースされ、php 5.4と互換性があります。楽しい!
私はapcu http://windows.php.net/downloads/pecl/releases/apcu/を見つけました
多分これはWindows上のx64用のapcです。それ(バージョン4.0.1)は私のアプリケーションで動作しました。
PHPバージョン5.5.19でAMPPSを使用しています。PHP 5.5のリリースからしばらく経ってから-APCは、PHP 5.5以降に含まれるZend OPCacheに置き換えられました。「APC」(現在は「OPcache」)を有効にするために必要なことは、php.iniを編集することだけです。[XDebug]セクションの前に次の行を追加します。
php.ini
...
[OPcache]
zend_extension=php_opcache.dll
opcache.enable=1
opcache.enable_cli=1
opcache.memory_consumption=512
opcache.interned_strings_buffer=24
opcache.max_accelerated_files=4000
opcache.revalidate_freq=3
opcache.fast_shutdown=1
...
次の2つのインスタンスが必要であることに注意してください。
zend_extension =
[OPcache]と[XDebug]セクションに1つずつ。Xdebugは多くの場合、xampp / ampps / easyPHPサーバーインストールのデフォルトとして提供されていません。Xdebugエクステンションをダウンロードする必要がある場合があります。これは、phpに適切なXdebugを定義するオンラインアプリケーションを使用して簡単に行うことができます。http://xdebug.org/wizard.phpにアクセスし、簡単な指示に従ってください。PHPバージョンに適したバージョンのXdebugをダウンロードしたら、[XDebug]セクションでzend_extensionのリンクを編集します。
...
[XDebug]
zend_extension = "C:\Program Files (x86)\Ampps\php\ext\php_xdebug-2.2.6-5.5-vc11.dll"
......
ご注意ください!php.iniファイルのXDebugの前にOPcacheセクションを追加する必要があります!!! 正しく私に従っていれば、php.iniファイルに2つのzend_extensionのインスタンスがあるはずです(1つはOPcacheにあり、もう1つはXdebugセクションにあります)。
これはSymfony2フレームワークに対して完全に機能し、PHPとXdebugにAPCをインストールして有効にするための推奨メッセージを排除します。
symfony 2を実行し、 "web / config.php"から警告メッセージを削除したものの、コマンドライン "php app / check.php"から実行すると問題が発生する人へのメッセージ。これが発生した場合は、コンソールが別のphp.iniファイルを使用していることを意味します。システムのPATH変数を変更します-正しいphpディレクトリ(php.exeファイルがあり、ローカルサーバーで使用されている場所)を指すようにします。
詳細な説明が必要な場合は、下のコメントでお知らせください。よろしく。
まだ解決されていない問題がいくつかあるようです。バグを確認すると、特定の問題の解決策を理解できる場合があります。
数時間前にそのようなエラーに対処しましたが、SVNトランクからAPCを使用する方法が適切であることがわかりました。お役に立てれば!
APCの新しいバージョン:1月2日以降の3.1.14は、いくつかのバグを解決しています:http ://pecl.php.net/package/APC
ただし、私はこれまで問題なくdotdebリポジトリからPHP 5.4.xとAPC 3.1.13を実行しており、安定していると言えます。dotdebはまた、アップデートされたAPCがPHPの次のリリースに含まれることを知らせてくれました。
XAMPPバージョン5.6.3(PHP 5.6.3)では、ini.phpで次のようにするだけです。
[OPcache]
zend_extension = php_opcache.dll
opcache.enable=1
opcache.enable_cli=1
opcache.memory_consumption=512
opcache.interned_strings_buffer=24
opcache.max_accelerated_files=4000
opcache.revalidate_freq=3
opcache.fast_shutdown=1
[XDebug]
zend_extension = "C:\xampp\php\ext\php_xdebug.dll"
xdebug.max_nesting_level = 200
xdebug.profiler_append = 1
xdebug.profiler_enable = 1
xdebug.profiler_enable_trigger = 0
;xdebug.profiler_output_dir = "C:\xampp\tmp"
;xdebug.profiler_output_name = "cachegrind.out.%t-%s"
;xdebug.remote_enable = 0
;xdebug.remote_handler = "dbgp"
;xdebug.remote_host = "127.0.0.1"
;xdebug.trace_output_dir = "C:\xampp\tmp"
symfony2フレームワークの設定。