Поведение функций зависит от установок в файле 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,
потому что он гораздо быстрее выделяет память при перезагрузке веб-сервера, что
сказывается на скорости запуска сервера.
Имя | По умолчанию | Место изменения | Список изменений |
---|---|---|---|
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 |
Краткое разъяснение конфигурационных директив.
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
Количество секунд, в течение которых запись кеша остаётся
в списке сборщика мусора после удаления или инвалидации.
Записи подлежат удалению, если количество ссылок на них равно нулю
или записи оставались в списке дольше этого ограничения времени.
Со значением 0
очистка по времени отключается,
а записи удаляются только тогда, когда количество ссылок на них обнуляется.
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.