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

Поведение этих функций зависит от установок в 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, потому что он гораздо быстрее выделяет память при перезагрузке веб-сервера, что сказывается на скорости запуска сервера.

Опции конфигурации 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 "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  
Дополнительная информация и описания режимов INI_* даны в разделе «Места установки параметров конфигурации».

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

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.

add a note

User Contributed Notes

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