Настройка во время выполнения

Поведение функций зависит от установок в файле php.ini.

Хотя настроек хранилища APCu по умолчанию достаточно для большинства задач, для серьёзных проектов необходимо внимательно изучить следующие настройки.

При настройке APCu необходимо определиться, сколько памяти предоставить в распоряжение APCu. Директива ini-файла, которая отвечает за эту настройку — apc.shm_size. Внимательно прочитайте нижеследующий раздел.

После запуска сервера скрипт apc.php, который поставляется вместе с модулем, следует скопировать в docroot и просмотреть в браузере, поскольку он предоставляет подробный анализ внутренней работы APCu. Если в PHP включён модуль GD, он даже отобразит некоторые интересные графики.

Если APCu работает, число Cache full count (слева) покажет, сколько раз кеш достигал максимальной ёмкости и был вынужден вытеснять записи, чтобы освободить память. Во время вытеснения, если указали значение apc.ttl, хранилище APCu сначала попытается удалить записи с истёкшим сроком действия, т. е. записи, TTL которых либо истёк, либо записи, у которых TTL не установлен и к которым не было доступа в течение последних apc.ttl секунд. Если значение apc.ttl не установили или удаление истёкших записей не освободило достаточно места, APCu очистит весь кеш.

В хорошо настроенном кеше количество вытеснений должно быть минимальным. Если кеш постоянно заполняется и, следовательно, принудительно освобождается, то возня, которая возникает в результате этого, негативно скажется на производительности скрипта. Самый простой способ минимизировать это число — выделить больше памяти для APCu.

Если APCu собрали с поддержкой mmap (Memory Mapping), оно будет использовать только один сегмент памяти, если же наоборот, APCu собрали с поддержкой SHM (SysV Shared Memory), оно будет использовать несколько сегментов. MMAP не имеет максимального ограничения, в отличие от SHM, который ограничивается /proc/sys/kernel/shmmax. Обычно рекомендуется использовать MMAP, потому что он гораздо быстрее выделяет память при перезагрузке веб-сервера, что сказывается на скорости запуска сервера.

Опции конфигурации APCu
Имя По умолчанию Место изменения Список изменений
apc.enabled 1 INI_SYSTEM  
apc.shm_segments 1 INI_SYSTEM  
apc.shm_size "32M" INI_SYSTEM  
apc.entries_hint 4096 INI_SYSTEM  
apc.ttl 0 INI_SYSTEM  
apc.gc_ttl 3600 INI_SYSTEM  
apc.mmap_file_mask NULL INI_SYSTEM  
apc.slam_defense 0 INI_SYSTEM  
apc.enable_cli 0 INI_SYSTEM  
apc.use_request_time 0 INI_ALL До APCu 5.1.19 значение по умолчанию равнялось 1.
apc.serializer "php" INI_SYSTEM До APCu 5.1.19 значение по умолчанию равнялось "default".
apc.coredump_unmap 0 INI_SYSTEM  
apc.preload_path NULL INI_SYSTEM  
Дополнительную информацию и определения режимов INI_* даёт раздел «Места установки параметров конфигурации».

Краткое разъяснение конфигурационных директив.

apc.enabled bool

Для опцпии apc.enabled устанавливают значение 0, чтобы отключить APC. Это в первую очередь полезно, когда APC статически компилируется в PHP, поскольку нет другого способа отключить его (при компиляции как DSO строку extension в файле php.ini можно просто закомментировать).

apc.shm_segments int

Количество сегментов разделяемой памяти, которые выделили под кеш компилятора. Если APC не хватает разделяемой памяти, но для опции apc.shm_size установили настолько максимальное значение, насколько разрешает система, увеличение этого значения может помешать APC исчерпать свою память. система.

apc.shm_size string

Размер сегмента разделяемой памяти, заданный в короткой нотации (смотрите этот FAQ). По умолчанию, некоторые системы (включая большинство вариантов BSD) ограничивают это значение крайне малым значением.

apc.entries_hint int

Это подсказка о количестве уникальных пользовательских переменных, которые надо кешировать. Установите равным нулю или вообще не указывайте, если не уверены.

apc.ttl int

Записи кеша без явного указания TTL считаются истёкшими, если к ним не обращались в течение этого количества секунд. По сути, это позволяет удалять такие записи оппортунистически во время добавления кеша или перед полным удалением. Обратите внимание, что поскольку удаление происходит по обстоятельствам, записи могут быть доступны для чтения, даже если их срок жизни превышает apc.ttl секунд. Параметр не влияет на записи кеша, для которых явно задан TTL.

apc.gc_ttl int

Количество секунд, которые запись может находиться в списке сборщика мусора. Это значение обеспечивает безотказность в случае падения сервера в момент исполнения закешированного файла. Если исполняемый файл был изменён, память, выделенная под кеширование его старой версии, не будет возвращена до истечения этого времени. Установка в ноль отключает этот функционал.

apc.mmap_file_mask string

Если собран с поддержкой MMAP через опцию --enable-mmap, этот параметр должен содержать файловую маску типа mktemp-style для передачи в модуль MMAP, чтобы определить, будет ли MMAP использовать файловую систему или разделяемую память. Для файловой системы опцию устанавливают так: /tmp/apc.XXXXXX (ровно 6 X). Чтобы использовать shm_open/mmap в стиле POSIX, в любом месте маски добавляют .shm, например: /apc.shm.XXXXXX. Чтобы использовать для анонимной памяти mmap интерфейс /dev/zero, который входит в ядро, для опции устанавливают значение /dev/zero. Если опцию оставили неопределённой, mmap будет анонимным.

apc.slam_defense bool

На очень загруженных серверах всякий раз, когда запускается веб-сервер или изменяются файлы, запускается гонка из множества процессов, которые попытаются закешировать один и тот же файл одновременно. Установка для опции apc.slam_defense значения 1 помогает предотвратить одновременное кеширование процессами одного и того же файла за счёт введения вероятностного механизма. Если разные процессы пытаются кешировать один и тот же ключ в течение короткого периода времени, кеширование для текущего процесса пропускается, чтобы уменьшить потенциальные сбои в кеше.

apc.enable_cli int

Больше для тестирования и отладки. Эта настройка включает APCu для CLI версии PHP. При обычной работе, запускать APCu, который будет создавать, наполнять и уничтожать кеш при каждом запуске сценария в консоли, будет далеко не лучшей идеей. Но в целях тестирования и отладки, можно легко включить APCu для CLI.

apc.serializer string

Указывает APC использовать сторонний сериализатор.

apc.coredump_unmap bool

Разрешает APC перехватывать сигналы, такие как SIGSEGV, который записывает coredump, когда подан. Когда эти сигналы будут получены, APC попытается освободить всю разделяемую память, чтобы не включать её в coredump. Эта настройка может увеличить стабильность системы, когда критический сигнал был получен, а APC сконфигурирован на использование большого объёма памяти.

Внимание

Эта возможность потенциально опасна. Освобождение сегментов разделяемой памяти при получении критического сигнала может привести к непредсказуемому поведению.

Замечание:

Хотя некоторые ядра предоставляют возможность игнорировать некоторые сегменты разделяемой памяти при записи core-файла, эти реализации могут также игнорировать важные сегменты памяти, такие как Apache scoreboard.

apc.preload_path string

Опционально. Задаёт путь, который используется APC для загрузки кешированных данных во время запуска.

apc.use_request_time bool

Использовать время старта запроса SAPI для TTL.

add a note

User Contributed Notes

There are no user contributed notes for this page.
To Top