PHP 5.5 был выпущен, и он имеет новый модуль кеширования кода под названием OPCache, но, похоже, документации для него нет.
Так где же документация для него и как мне использовать OPcache?
PHP 5.5 был выпущен, и он имеет новый модуль кеширования кода под названием OPCache, но, похоже, документации для него нет.
Так где же документация для него и как мне использовать OPcache?
Ответы:
OpCache компилируется по умолчанию на PHP5.5 +. Однако по умолчанию он отключен. Чтобы начать использовать OpCache в PHP5.5 +, вам сначала нужно его включить. Для этого вам нужно будет сделать следующее.
Добавьте следующую строку в ваш php.ini
:
zend_extension=/full/path/to/opcache.so (nix)
zend_extension=C:\path\to\php_opcache.dll (win)
Обратите внимание, что когда путь содержит пробелы, вы должны заключить его в кавычки:
zend_extension="C:\Program Files\PHP5.5\ext\php_opcache.dll"
Также обратите внимание, что вам придется использовать zend_extension
директиву вместо «нормальной» extension
директивы, потому что она влияет на реальный движок Zend (то есть на то, что запускает PHP).
В настоящее время есть четыре функции, которые вы можете использовать:
opcache_get_configuration()
:Возвращает массив, содержащий текущую используемую конфигурацию, которую использует OpCache. Это включает в себя все настройки ini, а также информацию о версии и занесенные в черный список файлы.
var_dump(opcache_get_configuration());
opcache_get_status()
:Это вернет массив с информацией о текущем состоянии кэша. Эта информация будет включать в себя такие вещи, как: состояние кэша (включен, перезапуск, заполнение и т. Д.), Использование памяти, попадания, пропуски и некоторая другая полезная информация. Он также будет содержать кэшированные скрипты.
var_dump(opcache_get_status());
opcache_reset()
:Сбрасывает весь кеш. Это означает, что все возможные кэшированные сценарии будут проанализированы снова при следующем посещении.
opcache_reset();
opcache_invalidate()
:Делает недействительным определенный кэшированный скрипт. Это означает, что сценарий будет проанализирован снова при следующем посещении.
opcache_invalidate('/path/to/script/to/invalidate.php', true);
Есть несколько графических интерфейсов, созданных для поддержки OpCache и создания полезных отчетов. Эти инструменты используют вышеупомянутые функции.
OpCacheGUI
Отказ от ответственности Я являюсь автором этого проекта
Особенности:
Скриншоты:
URL: https://github.com/PeeHaa/OpCacheGUI
opcache-статус
Особенности:
Скриншот:
URL: https://github.com/rlerdorf/opcache-status
opcache-гуй
Особенности:
Скриншот:
Поскольку OPcache предназначен для замены модуля APC, невозможно запустить их параллельно в PHP. Это хорошо для кэширования кода операции PHP, поскольку ни один из них не влияет на то, как вы пишете код.
Однако это означает, что если вы в настоящее время используете APC для хранения других данных (через apc_store()
функцию), вы не сможете сделать это, если решите использовать OPCache.
Вам нужно будет использовать другую библиотеку, такую как APCu или Yac, которая хранит данные в общей памяти PHP, или переключиться на использование чего-то вроде memcached, который хранит данные в памяти в отдельном процессе для PHP.
Кроме того, OPcache не имеет эквивалента индикатора выполнения загрузки, присутствующего в APC. Вместо этого вы должны использовать прогресс загрузки сеанса .
Документацию по OPcache можно найти здесь со всеми перечисленными здесь параметрами конфигурации . Рекомендуемые настройки:
; Sets how much memory to use
opcache.memory_consumption=128
;Sets how much memory should be used by OPcache for storing internal strings
;(e.g. classnames and the files they are contained in)
opcache.interned_strings_buffer=8
; The maximum number of files OPcache will cache
opcache.max_accelerated_files=4000
;How often (in seconds) to check file timestamps for changes to the shared
;memory storage allocation.
opcache.revalidate_freq=60
;If enabled, a fast shutdown sequence is used for the accelerated code
;The fast shutdown sequence doesn't free each allocated block, but lets
;the Zend Engine Memory Manager do the work.
opcache.fast_shutdown=1
;Enables the OPcache for the CLI version of PHP.
opcache.enable_cli=1
Если вы используете любую библиотеку или код, который использует аннотации кода, вы должны включить сохранение комментариев:
opcache.save_comments=1
Если отключено, все комментарии PHPDoc удаляются из кода, чтобы уменьшить размер оптимизированного кода. Отключение «Комментарии к документу» может привести к поломке некоторых существующих приложений и платформ (например, Doctrine, ZF2, PHPUnit)
Я собираюсь оставить свои два цента за то, что я использую opcache.
Я сделал обширную структуру со множеством полей, методов проверки и перечислений, чтобы иметь возможность общаться с моей базой данных.
Без opcache
При использовании этого сценария без opcache, и я отправляю 9000 запросов за 2,8 секунды на сервер apache, он достигает максимальной скорости 90-100% в течение 70-80 секунд до тех пор, пока не будет обработан все запросы.
Total time taken: 76085 milliseconds(76 seconds)
С включенным opcache
При включенном opcache он работает с 25-30% времени процессора в течение примерно 25 секунд и никогда не пропускает 25% использования процессора.
Total time taken: 26490 milliseconds(26 seconds)
Я создал файл черного списка opcache, чтобы отключить кэширование всего, кроме фреймворка, который является статическим и не требует изменения функциональности. Я явно выбираю только файлы фреймворка, чтобы я мог разрабатывать, не беспокоясь о перезагрузке / проверке файлов кеша. Кэширование всего сохраняет секунду на общем количестве запросов.25546 milliseconds
Это значительно расширяет объем данных / запросов, которые я могу обработать в секунду, даже если сервер не сломается.
zend_extension=php_opcache.dll; opcache.memory_consumption=128; opcache.interned_strings_buffer=8; opcache.max_accelerated_files=4000; opcache.revalidate_freq=60; opcache.fast_shutdown=1; opcache.enable_cli=1; opcache.blacklist_filename="C:\xampp\php\cfg\opcache.blacklist;
Просто замените; с вводом в INI-файл. Но это то, что я использовал. в основном материал по умолчанию
opcache.revalidate_freq=60;
определяет, как долго файл может находиться в памяти в секундах. когда время истекло, он перекомпилирует файл.
opcache.revalidate_freq
контролирует, как часто скрипт проверяется на наличие изменений (в зависимости от того, была ли изменена его временная метка). Таким образом, если временная метка скрипта остается такой же, как в последний раз, когда он был скомпилирован, она не будет перекомпилирована. Все это предполагает, что вы не изменили opcache.validate_timestamps
настройку, которая включена по умолчанию.
С PHP 5.6 на Amazon Linux (должно быть то же самое на RedHat или CentOS):
yum install php56-opcache
а затем перезапустите Apache.
Я сталкивался с этим при настройке Moodle. Я добавил следующие строки в файл php.ini.
zend_extension=C:\xampp\php\ext\php_opcache.dll
[opcache]
opcache.enable = 1
opcache.memory_consumption = 128
opcache.max_accelerated_files = 4000
opcache.revalidate_freq = 60
; Required for Moodle
opcache.use_cwd = 1
opcache.validate_timestamps = 1
opcache.save_comments = 1
opcache.enable_file_override = 0
; If something does not work in Moodle
;opcache.revalidate_path = 1 ; May fix problems with include paths
;opcache.mmap_base = 0x20000000 ; (Windows only) fix OPcache crashes with event id 487
; Experimental for Moodle 2.6 and later
;opcache.fast_shutdown = 1
;opcache.enable_cli = 1 ; Speeds up CLI cron
;opcache.load_comments = 0 ; May lower memory use, might not be compatible with add-ons and other apps
extension=C:\xampp\php\ext\php_intl.dll
[intl]
intl.default_locale = en_utf8
intl.error_level = E_WARNING
opcache.fast_shutdown = 0
github.com/zendtech/ZendOptimizerPlus/issues/146