Поведение этих функций зависит от установок в 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), он будет использовать
всего один сегмент памяти, если же наоборот, APC собран с поддержкой SHM (SysV Shared
Memory), он будет использовать несколько сегментов. MMAP не имеет максимального
ограничения, в отличие от SHM, который ограничивается
/proc/sys/kernel/shmmax
. Обычно рекомендуется использовать MMAP,
потому что он гораздо быстрее выделяет память при перезагрузке веб-сервера, что
сказывается на скорости запуска сервера.
Имя | По умолчанию | Место изменения | Список изменений |
---|---|---|---|
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 | "1" | 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 |
Краткое разъяснение конфигурационных директив.
apc.enabled
bool
Если установить apc.enabled
равным 0, то APCu не будет запущен.
Это полезно, когда APCu статически включён в PHP и нет других вариантов, для запрещения
его использования. Если APC собран как DSO, можно просто закомментировать строку
extension
в php.ini
.
apc.shm_segments
int
Количество сегментов разделяемой памяти выделенной под кеш.
Если APC использовал всю доступную разделяемую память, а
apc.shm_size
таким большим, как позволяет система, увеличение
этого параметра может помочь.
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
Вы также можете установить его как /dev/zero
для использования
интерфейса ядра /dev/zero
для анонимной памяти mmap.
Если не задано, то будет принудительно использоваться анонимный mmap.
apc.slam_defense
int
На очень загруженных серверах, когда вы запускаете веб-сервер,
сразу множество процессов будут пытаться закешировать один и тот же
файл одновременно. Этой опцией задаётся вероятность, в процентах,
того, что попытка одного конкретного процесса закешировать данные
будет отклонена. Например, если apc.slam_defense
установить равной 75
, то это означает, что
вероятность закешировать файл, которого в кеше нет,
будет равна 25% и вероятность того, что в кешировании будет
отказано равна 75%. Для запрета данного функционала установите
этот параметр равным 0
.
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.