Опции настройки модуля OPcache&Name;&Default;&Changeable;&Changelog;opcache.enable1INI_ALLopcache.enable_cli0INI_SYSTEMМежду PHP 7.1.2 и 7.1.6 включительно значение по умолчанию было равно 1opcache.memory_consumption128INI_SYSTEMopcache.interned_strings_buffer8INI_SYSTEMopcache.max_accelerated_files10000INI_SYSTEMopcache.max_wasted_percentage5INI_SYSTEMopcache.use_cwd1INI_SYSTEMopcache.validate_timestamps1INI_ALLopcache.revalidate_freq2INI_ALLopcache.revalidate_path0INI_ALLopcache.save_comments1INI_SYSTEMopcache.fast_shutdown0INI_SYSTEMopcache.enable_file_override0INI_SYSTEMopcache.optimization_level0x7FFEBFFFINI_SYSTEMДо PHP 7.3.0 значение равнялось 0x7FFFBFFFopcache.inherited_hack1INI_SYSTEMУдалили в PHP 7.3.0opcache.dups_fix0INI_ALLopcache.blacklist_filename""INI_SYSTEMopcache.max_file_size0INI_SYSTEMopcache.consistency_checks0INI_ALLОпцию отключили с PHP 8.1.18 и 8.2.5 и удалили в PHP 8.3.0.opcache.force_restart_timeout180INI_SYSTEMopcache.error_log""INI_SYSTEMopcache.log_verbosity_level"1"INI_SYSTEMopcache.record_warnings0INI_SYSTEMОпция доступна с PHP 8.0.0.opcache.preferred_memory_model""INI_SYSTEMopcache.protect_memory0INI_SYSTEMopcache.mmap_base&null;INI_SYSTEMОпция доступна только на ОС Windows.opcache.restrict_api""INI_SYSTEMopcache.file_update_protection2INI_ALLopcache.huge_code_pages0INI_SYSTEMopcache.lockfile_path"/tmp"INI_SYSTEMopcache.opt_debug_level0INI_SYSTEMОпция доступна с PHP 7.1.0opcache.file_cache&null;INI_SYSTEMopcache.file_cache_only0INI_SYSTEMopcache.file_cache_consistency_checks1INI_SYSTEMopcache.file_cache_fallback1INI_SYSTEMopcache.validate_permission0INI_SYSTEMОпция доступна с PHP 7.0.14opcache.validate_root0INI_SYSTEMОпция доступна с PHP 7.0.14opcache.preload""INI_SYSTEMОпция доступна с PHP 7.4.0opcache.preload_user""INI_SYSTEMОпция доступна с PHP 7.4.0opcache.cache_id""INI_SYSTEMОпция доступна с PHP 7.4.0 только на ОС Windowsopcache.jit"tracing"INI_ALLОпция доступна с PHP 8.0.0opcache.jit_buffer_size0INI_SYSTEMОпция доступна с PHP 8.0.0opcache.jit_debug0INI_ALLОпция доступна с PHP 8.0.0opcache.jit_bisect_limit0INI_ALLОпция доступна с PHP 8.0.0opcache.jit_prof_threshold0.005INI_ALLОпция доступна с PHP 8.0.0opcache.jit_max_root_traces1024INI_SYSTEMОпция доступна с PHP 8.0.0opcache.jit_max_side_traces128INI_SYSTEMОпция доступна с PHP 8.0.0opcache.jit_max_exit_counters8192INI_SYSTEMОпция доступна с PHP 8.0.0opcache.jit_hot_loop64INI_SYSTEMОпция доступна с PHP 8.0.0opcache.jit_hot_func127INI_SYSTEMОпция доступна с PHP 8.0.0opcache.jit_hot_return8INI_SYSTEMОпция доступна с PHP 8.0.0opcache.jit_hot_side_exit8INI_SYSTEMОпция доступна с PHP 8.0.0opcache.jit_blacklist_root_trace16INI_ALLОпция доступна с PHP 8.0.0opcache.jit_blacklist_side_trace8INI_ALLОпция доступна с PHP 8.0.0opcache.jit_max_loop_unrolls8INI_ALLОпция доступна с PHP 8.0.0opcache.jit_max_recursive_calls2INI_ALLОпция доступна с PHP 8.0.0opcache.jit_max_recursive_returns2INI_ALLОпция доступна с PHP 8.0.0opcache.jit_max_polymorphic_calls2INI_ALLОпция доступна с PHP 8.0.0
&ini.php.constants;
&ini.descriptions.title;
opcache.enablebool
Включает кеш опкодов. Код не оптимизируется и не кешируется,
если опцию отключили. Опцию opcache.enable нельзя включить
во время выполнения функцией ini_set, но можно отключить.
Попытка включить опцию в скрипте выдаст предупреждение.
opcache.enable_clibool
Включает кеш опкодов для CLI-версии PHP.
opcache.memory_consumptionint
Размер разделяемой памяти в мегабайтах для OPcache.
Минимально допустимое значение — 8,
которое кеш опкодов займёт, если установили значение меньше.
opcache.interned_strings_bufferint
Количество памяти в мегабайтах для хранения интернированных строк.
opcache.max_accelerated_filesint
Максимальное количество ключей (и, соответственно, скриптов) в хеш-таблице
OPcache. Значение, которое кеш опкодов будет использовать в итоге, будет первым числом из набора
{ 223, 463, 983, 1979, 3907, 7963, 16229, 32531, 65407, 130987, 262237, 524521, 1048793 },
которое больше или равно значению, которое установили для этого параметра.
Минимальное значение составляет 200, а максимальное — 1 000 000.
Значения за пределами этого диапазона ограничиваются допустимым диапазоном.
opcache.max_wasted_percentageint
Максимальный процент неиспользуемой памяти, при достижении которого модуль
запланирует перезапуск, если свободной памяти недостаточно.
Максимально допустимое значение: 50,
которое кеш опкодов займёт, если установили значение больше.
opcache.use_cwdbool
При включении опции OPcache добавляет текущую рабочую директорию к ключу
скрипта, чем устраняет возможность коллизий для файлов с одинаковым
основным именем. Отключение этой директивы повышает производительность, но иногда
приводит к сбоям приложений.
opcache.validate_timestampsbool
При включении опции OPcache будет проверять актуальность закешированных скриптов каждые
opcache.revalidate_freq
секунд. При отключении директивы требуется сбросить OPcache вручную функциями
opcache_reset
и opcache_invalidate или перезапустить веб-сервер, чтобы
изменения в файловой системе вступили в силу.
OPcache по-прежнему может проверять метку времени файла во время компиляции, если для
опций opcache.file_update_protection
или opcache.max_file_size установили ненулевые значения.
opcache.revalidate_freqint
Как часто в секундах проверять обновления меток времени скрипта.
При значении 0 OPcache будет проверять обновления
при каждом запросе.
Модуль игнорирует эту директиву конфигурации, если опцию
opcache.validate_timestamps отключили.
opcache.revalidate_pathbool
При отключении опции модуль переиспользует файлы кеша,
пути которых содержат путь из списка include_path.
Поэтому модуль не будет искать файл с таким же именем по другим путям
списка include_path.
opcache.save_commentsbool
При отключении опции модуль отбрасывает комментарии для документации из кеша опкодов,
чтобы уменьшить размер оптимизированного кода. Отключение этой директивы конфигурации может спровоцировать
сбой в работе приложений и фреймворков, которые полагаются на аннотации в комментариях,
включая Doctrine, Zend Framework 2 и PHPUnit.
opcache.fast_shutdownbool
При включении опции используется последовательность быстрого завершения работы,
которая не освобождает каждый выделенный блок памяти, а полагается
на менеджер памяти движка Zend Engine для массового освобождения всего набора переменных запроса.
Эту директиву удалили в PHP 7.2.0. Вариант последовательности
быстрого завершения работы интегрировали в PHP и кеш опкодов по возможности
будет использовать вариант автоматически.
opcache.enable_file_overridebool
При включении опции и вызове функций file_exists,
is_file и is_readable
модуль будет проверять, содержит ли уже кеш опкодов файл.
Опция может повысить производительность приложений, которые проверяют наличие
и доступность для чтения PHP-скриптов, но рискует вернуть устаревшие
данные, если опцию
opcache.validate_timestamps отключили.
opcache.optimization_levelint
Битовая маска, которая контролирует, какие шаги оптимизации выполняются.
По умолчанию применяются все безопасные оптимизации.
Изменение значения по умолчанию в основном полезно для отладки или разработки оптимизатора
(смотрите также описание директивы opcache.opt_debug_level).
opcache.inherited_hackbool
Эта директива конфигурации игнорируется.
opcache.dups_fixbool
Этот хак требуется только для обхода ошибок «Невозможно повторно объявить класс» (Cannot redeclare class).
opcache.blacklist_filenamestring
Расположение файла чёрного списка OPcache. Файл чёрного списка — текстовый файл,
который содержит имена файлов, которые не нужно ускорять, по одной записи на строку.
Допускаются подстановочные знаки, также можно указывать префиксы. Строки, которые
начинаются с точки с запятой, игнорируются как комментарии.
Пример простого чёрного списка:
opcache.max_file_sizeint
Максимальный размер файла для кеширования в байтах.
Модуль будет кешировать все файлы, если значение равно 0.
opcache.consistency_checksint
Если значение ненулевое, OPcache будет сверять контрольную сумму кеша каждые N запросов,
где N — значение этой директивы конфигурации. Рекомендуется включать директиву только
при отладке, поскольку опция снижает производительность.
Опцию отключили с PHP 8.1.18 и 8.2.5 и удалили в PHP 8.3.0.
opcache.force_restart_timeoutint
Время ожидания начала запланированного перезапуска в секундах при неактивном кеше.
Если время ожидания истекло,
OPcache решает, что что-то не так, и чтобы разрешить перезапуск, завершит процессы,
которые удерживают блокировки в кеше.
Если для параметра
opcache.log_verbosity_level
установили значение 2 или больше, то когда возникнет ситуации с превышением времени ожидания,
модуль запишет в лог ошибок предупреждение.
Директива не поддерживается в ОС Windows.
opcache.error_logstring
Путь к логу ошибок OPcache. Пустая строка обрабатывается как stderr,
и приведёт к отправке логов в стандартный поток ошибок (обычно это лог
ошибок веб-сервера).
opcache.log_verbosity_levelint
Уровень детализации лога ошибок. По умолчанию регистрируются только
фатальные ошибки (уровень 0) и ошибки (уровень 1).
Другие доступные уровни: предупреждения (уровень 2), информационные
сообщения (уровень 3) и сообщения отладки (уровень 4).
opcache.record_warningsbool
При включении опции OPcache будет записывать предупреждения, которые возникают во время компиляции,
и повторять их при следующем включении файла, даже если файл обслуживается из кеша.
opcache.preferred_memory_modelstring
Предпочитаемая модель памяти для OPcache. Если оставить значение пустым,
OPcache сам выберет наиболее подходящую модель, которая
будет вести себя корректно практически в любых случаях.
Возможные значения включают mmap, shm,
posix и win32.
opcache.protect_memorybool
Защищает разделяемую память от неожиданной записи во время запуска скриптов.
Полезно только для внутренней отладки.
opcache.mmap_basestring
Базовое значение для сегмента разделяемой памяти в ОС Windows. Каждый
PHP-процесс должен отображать разделяемую память в одинаковое адресное пространство.
Эта директива помогает исправить ошибки «Не удается повторно прикрепиться к базовому адресу»
(Unable to reattach to base address).
opcache.restrict_apistring
Разрешает вызывать API-функции модуля OPcache только из PHP-скриптов, чей путь начинается
с заданной строки. Значение по умолчанию равно "" и означает отсутствие ограничений.
opcache.file_update_protectionstring
Исключает кеширование файлов, с момента изменения которых прошло меньше секунд, чем указали.
Это защищает от кеширования неполностью обновлённых файлов. Если все обновления файлов атомарны, можно повысить
производительность, задав для этого параметра значение 0.
Это разрешит закешировать файлы немедленно.
opcache.huge_code_pagesbool
Включает или отключает копирование PHP-кода (текстового сегмента) в HUGE PAGES.
Опция может повысить производительность, но требует соответствующих системных
настроек.
Опция доступна в Linux начиная с PHP 7.0.0 и во FreeBSD начиная с PHP 7.4.0.
opcache.lockfile_pathstring
Абсолютный путь к хранилищу общих файлов блокировок (только для *nix-систем).
opcache.opt_debug_levelstring
Создаёт сброс опкодов для отладки отдельных этапов оптимизации.
Значение 0x10000 будет выводить опкоды в том виде, в каком их создал компилятор,
до оптимизации, тогда как значение
0x20000 будет выводить оптимизированные опкоды.
opcache.file_cachestring
Включает и устанавливает каталог кеша второго уровня. Опция должна
повысить производительность, когда SHM-память заполнилась,
при перезапуске сервера или сбросе разделяемой SHM-памяти. Значение по умолчанию ""
отключает кеширование на основе файлов.
opcache.file_cache_onlybool
Включает или выключает кеширование опкодов в разделяемой памяти.
До PHP 8.1.0 отключение этой директивы с уже заполненным
файловым кешем требовало ручной очистки файлового кеша.
opcache.file_cache_consistency_checksbool
Включает или выключает проверку контрольной суммы при загрузке скрипта
из файлового кеша.
opcache.file_cache_fallbackbool
Подразумевает opcache.file_cache_only=1 для конкретного процесса, которому
не удалось повторно подключиться к разделяемой памяти
(только для ОС Windows). Требуется явное включение файлового кеша.
Отключение этой опции конфигурации может помешать запуску процессов, и поэтому не рекомендуется.
opcache.validate_permissionbool
Проверяет права доступа к кешированному файлу для текущего пользователя.
opcache.validate_rootbool
Предотвращает коллизии имён в chroot-окружении. Опцию необходимо включать
для каждого chroot-окружения, чтобы предотвратить доступ
к файлам за пределами chroot.
opcache.preloadstring
Задаёт PHP-скрипт, который модуль скомпилирует и выполнит при старте сервера,
а также сможет предзагрузить другие файлы, либо через конструкцию include,
либо через функцию opcache_compile_file. Каждая сущность (например,
функции и классы), которую определили в этих файлах, будет автоматически доступна для запросов
до момента выключения сервера.
Предварительная загрузка не поддерживается ОС Windows.
opcache.preload_userstring
Позволяет запускать предварительную загрузку от имени заданного пользователя системы.
Опция полезна для серверов, которые запускаются от имени root-пользователя перед переключением
на непривилегированного пользователя системы.
По умолчанию предварительная загрузка от имени root запрещена по соображениям безопасности,
если только этой директиве явно не установили значение root.
opcache.cache_idstring
В системах Windows процессы, которые запускают один и тот же SAPI-интерфейс PHP
под одной и той же учётной записью пользователя с тем же идентификатором кеша, делят между собой один экземпляр OPcache.
Значение этой опции разрешается задавать произвольно.
На IIS-серверах пулы приложений поддерживают способность работать с отдельными экземплярами OPcache.
Чтобы разделить кеши, переменную окружения APP_POOL_ID указывают как идентификатор кеша
opcache.cache_id.
opcache.jitstringint
В обычном режиме параметр принимает одно из четырёх строковых значений:
disable: Деактивирован, нельзя включить во время выполнения.off: Выключен, но разрешается включить во время выполнения.tracing/on: Включить JIT с компиляцией трассировок.
Включён по умолчанию и рекомендуется для большей части пользователей.
function: Включить JIT с компиляцией функций.
В продвинутом режиме параметр принимает 4-значное целое число CRTO, в котором цифры означают:
C (флаги оптимизации для процессора)0: Отключить оптимизацию для ЦП.1: Включить набор инструкций AVX, если поддерживается ЦП.R (распределение регистров)0: Не распределять регистры.1: Выделять локальный блочный регистр.2: Выделять глобальный регистр.T (триггер)0: Компилировать каждую функцию при загрузке скрипта.1: Компилировать функций при первом выполнении.2: Профилировать функции при первом запросе и компилировать самые горячие функции.
3: Профилировать на лету и компилировать горячие функции.4: Не используется.5: Включить JIT с компиляцией трассировок.
Профилировать на лету и компилировать трассировки горячих сегментов кода.
O (уровень оптимизации)0: Без JIT-компилятора.1: Минимальный уровень JIT-компиляции (вызывать стандартные обработчики виртуальной машины).2: Вызывать встроенные обработчики виртуальной машины.3: Разрешить компилятору делать выводы о типах значений.4: Использовать граф вызовов.5: Оптимизировать весь скрипт.
Режим tracing соответствует CRTO = 1254,
Режим function соответствует CRTO = 1205.
opcache.jit_buffer_sizeint
Объем разделяемой памяти, который резервируется для скомпилированного JIT-кода. Нулевое значение отключает JIT.
&ini.shorthandbytes;
opcache.jit_debugint
Битовая маска, которая определяет, какой вывод JIT-отладки включить.
Возможные значения смотрите в файле zend_jit.h
(ищите определения макросов, которые начинаются с префикса ZEND_JIT_DEBUG).
opcache.jit_bisect_limitint
Опция отладки, которая отключает JIT-компиляцию после компиляции конкретного количества функций.
Опция помогает разделять источник неправильной JIT-компиляции.
Примечание: этот параметр работает, только если для JIT-триггера установили значение 0 (компиляция при загрузке скрипта)
или 1 (компиляция при первом выполнении), например opcache.jit=1215.
Подробнее о значениях рассказывает описание опции opcache.jit.
opcache.jit_prof_thresholdfloat
Когда используется режим триггера «профилирование функций при первом запросе» этот порог определяет, считается ли
функция горячей. Количество вызовов функции, разделённое на количество вызовов
всех функций, должно быть выше порогового значения. Например, пороговое значение 0,005 означает,
что функции, которые составляют более 0,5% всех вызовов, будут компилироваться JIT-компилятором.
opcache.jit_max_root_tracesint
Максимальное количество корневых стеков вызовов.
Корневой стек вызова — поток выполнения, который сначала проходит по одному пути через код,
что является единицей JIT-компиляции.
JIT не будет компилировать новый код, если достигнет этого предела.
opcache.jit_max_side_tracesint
Максимальное количество боковых стеков вызова, которые могут принадлежать корневому стеку.
Боковой стек вызова — другой поток выполнения, который не идёт по пути скомпилированного корневого стека вызова.
Боковые стеки вызова, которые принадлежат тому же корневому стеку вызова, не будут компилироваться,
если достигнут этого предела.
opcache.jit_max_exit_countersint
Максимальное количество счётчиков выхода бокового стека вызова. Опция ограничивает общее количество
возможных боковых стеков вызова для всех корневых стеков.
opcache.jit_hot_loopint
После скольких итераций цикл считается горячим.
Допустимый диапазон значений: [0,255]; для значений за пределами этого диапазона,
например -1 или 256, будет использоваться значение по умолчанию.
Значение 0 отключит трассировку и компиляцию циклов JIT-компилятором.
opcache.jit_hot_funcint
После скольких вызовов функция считается горячей.
Допустимый диапазон значений: [0,255]; для значений за пределами этого диапазона,
например -1 или 256, будет использоваться значение по умолчанию.
Значение 0 отключит трассировку и компиляцию функций JIT-компилятором.
opcache.jit_hot_returnint
После скольких возвратов возврат считается горячим.
Допустимый диапазон значений: [0,255]; для значений за пределами этого диапазона,
например -1 или 256, будет использоваться значение по умолчанию.
Значение 0 отключит трассировку и компиляцию возвратов JIT-компилятором.
opcache.jit_hot_side_exitint
После скольких выходов выход из бокового стека вызова считается горячим.
Допустимый диапазон значений: [0,255]; для значений за пределами этого диапазона,
например -1 или 256, будет использоваться значение по умолчанию.
Значение 0 отключит трассировку и компиляцию боковых выходов JIT-компилятором.
opcache.jit_blacklist_root_traceint
Максимальное количество попыток компиляции корневого стека вызова, прежде чем компилятор занесёт корневой стек в чёрный список.
opcache.jit_blacklist_side_traceint
Максимальное количество попыток компиляции бокового стека вызова, прежде чем компилятор занесёт боковой стек в чёрный список.
opcache.jit_max_loop_unrollsint
Максимальное количество попыток развернуть цикл в боковом пути
при попытке достичь корневого пути и закрыть внешний цикл.
opcache.jit_max_recursive_callsint
Максимальное количество развёрнутых циклов рекурсивных вызовов.
opcache.jit_max_recursive_returnsint
Максимальное количество развёрнутых циклов рекурсивных возвратов.
opcache.jit_max_polymorphic_callsint
Максимальное количество попыток встроить полиморфные динамические вызовы или вызовы полиморфных методов.
Вызовы, которые превышают этот предел, обрабатываются как мегаморфные и не встраиваются.