<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/apcu.setup.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ru',
  ),
  'this' => 
  array (
    0 => 'apcu.configuration.php',
    1 => 'Настройка во время выполнения',
    2 => 'Настройка во время выполнения',
  ),
  'up' => 
  array (
    0 => 'apcu.setup.php',
    1 => 'Установка и настройка',
  ),
  'prev' => 
  array (
    0 => 'apcu.installation.php',
    1 => 'Установка',
  ),
  'next' => 
  array (
    0 => 'apcu.constants.php',
    1 => 'Предопределённые константы',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ru',
    'path' => 'reference/apcu/ini.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="apcu.configuration" class="section">
 <h2 class="title">Настройка во время выполнения</h2>
 <p class="simpara">
Поведение функций зависит от установок в файле <var class="filename">php.ini</var>.
</p>
 <p class="simpara">
  Хотя настроек хранилища APCu по умолчанию достаточно для большинства задач, для
  серьёзных проектов необходимо внимательно изучить следующие настройки.
 </p>
 <p class="simpara">
  При настройке APCu необходимо определиться, сколько памяти
  предоставить в распоряжение APCu.
  Директива ini-файла, которая отвечает за эту настройку — <code class="literal">apc.shm_size</code>.
  Внимательно прочитайте нижеследующий раздел.
 </p>
 <p class="simpara">
  После запуска сервера скрипт <code class="literal">apc.php</code>, который поставляется вместе с модулем,
  следует скопировать в docroot и просмотреть в браузере, поскольку он предоставляет
  подробный анализ внутренней работы APCu.
  Если в PHP включён модуль GD, он даже отобразит некоторые интересные графики.
 </p>
 <p class="simpara">
  Если APCu работает, число <code class="literal">Cache full count</code> (слева) покажет,
  сколько раз кеш достигал максимальной ёмкости и был вынужден вытеснять записи,
  чтобы освободить память.
  Во время вытеснения, если указали значение <code class="literal">apc.ttl</code>,
  хранилище APCu сначала попытается удалить записи с истёкшим сроком действия, т. е. записи,
  TTL которых либо истёк, либо записи, у которых TTL не установлен
  и к которым не было доступа в течение последних <code class="literal">apc.ttl</code> секунд.
  Если значение <code class="literal">apc.ttl</code> не установили или удаление истёкших записей
  не освободило достаточно места, APCu очистит весь кеш.
 </p>
 <p class="simpara">
  В хорошо настроенном кеше количество вытеснений должно быть минимальным.
  Если кеш постоянно заполняется и, следовательно, принудительно освобождается,
  то возня, которая возникает в результате этого, негативно скажется на производительности скрипта.
  Самый простой способ минимизировать это число — выделить больше памяти для APCu.
 </p>
 <p class="simpara">
  Если APCu собрали с поддержкой mmap (Memory Mapping), оно будет использовать
  только один сегмент памяти, если же наоборот, APCu собрали с поддержкой SHM (SysV Shared
  Memory), оно будет использовать несколько сегментов. MMAP не имеет максимального
  ограничения, в отличие от SHM, который ограничивается
  <code class="literal">/proc/sys/kernel/shmmax</code>. Обычно рекомендуется использовать MMAP,
  потому что он гораздо быстрее выделяет память при перезагрузке веб-сервера, что
  сказывается на скорости запуска сервера.
 </p>
 <p class="para">
  <table class="doctable table">
   <caption><strong>Опции конфигурации APCu</strong></caption>
   
    <thead>
     <tr>
      <th>Имя</th>
      <th>По умолчанию</th>
      <th>Место изменения</th>
      <th>Список изменений</th>
     </tr>

    </thead>

    <tbody class="tbody">
     <tr>
      <td><a href="apcu.configuration.php#ini.apcu.enabled" class="link">apc.enabled</a></td>
      <td>1</td>
      <td><strong><code><a href="info.constants.php#constant.ini-system">INI_SYSTEM</a></code></strong></td>
      <td class="empty">&nbsp;</td>
     </tr>

     <tr>
      <td><a href="apcu.configuration.php#ini.apcu.shm-segments" class="link">apc.shm_segments</a></td>
      <td>1</td>
      <td><strong><code><a href="info.constants.php#constant.ini-system">INI_SYSTEM</a></code></strong></td>
      <td class="empty">&nbsp;</td>
     </tr>

     <tr>
      <td><a href="apcu.configuration.php#ini.apcu.shm-size" class="link">apc.shm_size</a></td>
      <td>&quot;32M&quot;</td>
      <td><strong><code><a href="info.constants.php#constant.ini-system">INI_SYSTEM</a></code></strong></td>
      <td class="empty">&nbsp;</td>
     </tr>

     <tr>
      <td><a href="apcu.configuration.php#ini.apcu.entries-hint" class="link">apc.entries_hint</a></td>
      <td>512 * apc.shm_size</td>
      <td><strong><code><a href="info.constants.php#constant.ini-system">INI_SYSTEM</a></code></strong></td>
      <td>До APcu 5.1.25 значение по умолчанию равнялось 4096.</td>
     </tr>

     <tr>
      <td><a href="apcu.configuration.php#ini.apcu.ttl" class="link">apc.ttl</a></td>
      <td>0</td>
      <td><strong><code><a href="info.constants.php#constant.ini-system">INI_SYSTEM</a></code></strong></td>
      <td class="empty">&nbsp;</td>
     </tr>

     <tr>
      <td><a href="apcu.configuration.php#ini.apcu.gc-ttl" class="link">apc.gc_ttl</a></td>
      <td>3600</td>
      <td><strong><code><a href="info.constants.php#constant.ini-system">INI_SYSTEM</a></code></strong></td>
      <td class="empty">&nbsp;</td>
     </tr>

     <tr>
      <td><a href="apcu.configuration.php#ini.apcu.mmap-file-mask" class="link">apc.mmap_file_mask</a></td>
      <td>NULL</td>
      <td><strong><code><a href="info.constants.php#constant.ini-system">INI_SYSTEM</a></code></strong></td>
      <td class="empty">&nbsp;</td>
     </tr>

     <tr>
      <td><a href="apcu.configuration.php#ini.apcu.slam-defense" class="link">apc.slam_defense</a></td>
      <td>0</td>
      <td><strong><code><a href="info.constants.php#constant.ini-system">INI_SYSTEM</a></code></strong></td>
      <td class="empty">&nbsp;</td>
     </tr>

     <tr>
      <td><a href="apcu.configuration.php#ini.apcu.enable-cli" class="link">apc.enable_cli</a></td>
      <td>0</td>
      <td><strong><code><a href="info.constants.php#constant.ini-system">INI_SYSTEM</a></code></strong></td>
      <td class="empty">&nbsp;</td>
     </tr>

     <tr>
      <td><a href="apcu.configuration.php#ini.apcu.use-request-time" class="link">apc.use_request_time</a></td>
      <td>0</td>
      <td><strong><code><a href="info.constants.php#constant.ini-all">INI_ALL</a></code></strong></td>
      <td>До APCu 5.1.19 значение по умолчанию равнялось <code class="literal">1</code>.</td>
     </tr>

     <tr>
      <td><a href="apcu.configuration.php#ini.apcu.serializer" class="link">apc.serializer</a></td>
      <td>&quot;php&quot;</td>
      <td><strong><code><a href="info.constants.php#constant.ini-system">INI_SYSTEM</a></code></strong></td>
      <td>До APCu 5.1.19 значение по умолчанию равнялось <code class="literal">&quot;default&quot;</code>.</td>
     </tr>

     <tr>
      <td><a href="apcu.configuration.php#ini.apcu.coredump-unmap" class="link">apc.coredump_unmap</a></td>
      <td>0</td>
      <td><strong><code><a href="info.constants.php#constant.ini-system">INI_SYSTEM</a></code></strong></td>
      <td class="empty">&nbsp;</td>
     </tr>

     <tr>
      <td><a href="apcu.configuration.php#ini.apcu.preload-path" class="link">apc.preload_path</a></td>
      <td>NULL</td>
      <td><strong><code><a href="info.constants.php#constant.ini-system">INI_SYSTEM</a></code></strong></td>
      <td class="empty">&nbsp;</td>
     </tr>

    </tbody>
   
  </table>

  Дополнительную информацию и определения режимов
INI_* даёт раздел «<a href="configuration.changes.modes.php" class="xref">Места установки параметров конфигурации</a>».
 </p>

 <p class="para">Краткое разъяснение конфигурационных
директив.</p>

 <dl>
  
   <dt id="ini.apcu.enabled">
    <code class="parameter">apc.enabled</code>
    <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>
   </dt>
   <dd>
    <span class="simpara">
     Для опцпии <code class="literal">apc.enabled</code> устанавливают значение 0, чтобы отключить APC.
     Это в первую очередь полезно, когда APC статически компилируется в PHP, поскольку нет другого способа
     отключить его (при компиляции как DSO строку <code class="literal">extension</code>
     в файле <code class="literal">php.ini</code> можно просто закомментировать).
    </span>
   </dd>
  
  
   <dt id="ini.apcu.shm-segments">
    <code class="parameter">apc.shm_segments</code>
    <span class="type"><a href="language.types.integer.php" class="type int">int</a></span>
   </dt>
   <dd>
    <span class="simpara">
     Количество сегментов разделяемой памяти, которые выделили под кеш компилятора.
     Если APC не хватает разделяемой памяти, но для опции
     <code class="literal">apc.shm_size</code> установили настолько максимальное значение, насколько
     разрешает система, увеличение этого значения может помешать APC исчерпать свою память.
     система.
    </span>
   </dd>
  
  
   <dt id="ini.apcu.shm-size">
    <code class="parameter">apc.shm_size</code>
    <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
   </dt>
   <dd>
    <span class="simpara">
     Размер сегмента разделяемой памяти, заданный в короткой нотации (смотрите
     <a href="faq.using.php#faq.using.shorthandbytes" class="link">этот FAQ</a>).
     По умолчанию, некоторые системы (включая большинство вариантов BSD)
     ограничивают это значение крайне малым значением.
    </span>
   </dd>
  
  
   <dt id="ini.apcu.entries-hint">
    <code class="parameter">apc.entries_hint</code>
    <span class="type"><a href="language.types.integer.php" class="type int">int</a></span>
   </dt>
   <dd>
    <span class="simpara">
     Это подсказка о количестве уникальных пользовательских переменных,
     которые надо кешировать. Установите равным нулю или вообще не
     указывайте, если не уверены.
    </span>
   </dd>
  
  
   <dt id="ini.apcu.ttl">
    <code class="parameter">apc.ttl</code>
    <span class="type"><a href="language.types.integer.php" class="type int">int</a></span>
   </dt>
   <dd>
    <span class="simpara">
     Записи кеша без явного указания TTL считаются истёкшими,
     если к ним не обращались в течение этого количества секунд.
     По сути, это позволяет удалять такие записи оппортунистически
     во время добавления кеша или перед полным удалением.
     Обратите внимание, что поскольку удаление происходит по обстоятельствам,
     записи могут быть доступны для чтения, даже если их срок жизни
     превышает <code class="literal">apc.ttl</code> секунд.
     Параметр не влияет на записи кеша, для которых явно задан TTL.
    </span>
   </dd>
  
  
   <dt id="ini.apcu.gc-ttl">
    <code class="parameter">apc.gc_ttl</code>
    <span class="type"><a href="language.types.integer.php" class="type int">int</a></span>
   </dt>
   <dd>
    <span class="simpara">
     Количество секунд, в течение которых запись кеша остаётся
     в списке сборщика мусора после удаления или инвалидации.
     Записи подлежат удалению, если количество ссылок на них равно нулю
     или записи оставались в списке дольше этого ограничения времени.
     Со значением <code class="literal">0</code> очистка по времени отключается,
     а записи удаляются только тогда, когда количество ссылок на них обнуляется.
    </span>
   </dd>
  
  
   <dt id="ini.apcu.mmap-file-mask">
    <code class="parameter">apc.mmap_file_mask</code>
    <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
   </dt>
   <dd>
    <span class="simpara">
     Если собран с поддержкой MMAP через опцию <code class="literal">--enable-mmap</code>,
     этот параметр должен содержать файловую маску типа mktemp-style для
     передачи в модуль MMAP, чтобы определить, будет ли MMAP использовать
     файловую систему или разделяемую память.
     Для файловой системы опцию устанавливают так: <code class="literal">/tmp/apc.XXXXXX</code>
     (ровно 6 <code class="literal">X</code>).
     Чтобы использовать shm_open/mmap в стиле POSIX, в любом месте маски
     добавляют <code class="literal">.shm</code>, например: <code class="literal">/apc.shm.XXXXXX</code>.
     Чтобы использовать для анонимной памяти mmap интерфейс <code class="literal">/dev/zero</code>, который входит в ядро,
     для опции устанавливают значение <code class="literal">/dev/zero</code>.
     Если опцию оставили неопределённой, mmap будет анонимным.
    </span>
   </dd>
  
  
   <dt id="ini.apcu.slam-defense">
    <code class="parameter">apc.slam_defense</code>
    <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>
   </dt>
   <dd>
    <span class="simpara">
     На очень загруженных серверах всякий раз, когда запускается веб-сервер
     или изменяются файлы, запускается гонка из множества процессов, которые
     попытаются закешировать один и тот же файл одновременно.
     Установка для опции <code class="literal">apc.slam_defense</code> значения <code class="literal">1</code>
     помогает предотвратить одновременное кеширование
     процессами одного и того же файла за счёт введения вероятностного
     механизма. Если разные процессы пытаются кешировать один и тот же ключ
     в течение короткого периода времени, кеширование
     для текущего процесса пропускается, чтобы уменьшить потенциальные
     сбои в кеше.
    </span>
   </dd>
  
  
   <dt id="ini.apcu.enable-cli">
    <code class="parameter">apc.enable_cli</code>
    <span class="type"><a href="language.types.integer.php" class="type int">int</a></span>
   </dt>
   <dd>
    <span class="simpara">
     Больше для тестирования и отладки. Эта настройка включает APCu
     для CLI версии PHP. При обычной работе, запускать APCu, который
     будет создавать, наполнять и уничтожать кеш при каждом запуске
     сценария в консоли, будет далеко не лучшей идеей. Но в целях
     тестирования и отладки, можно легко включить APCu для CLI.
    </span>
   </dd>
  
  
   <dt id="ini.apcu.serializer">
    <code class="parameter">apc.serializer</code>
    <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
   </dt>
   <dd>
    <span class="simpara">
     Указывает APC использовать сторонний сериализатор.
    </span>
   </dd>
  
  
   <dt id="ini.apcu.coredump-unmap">
    <code class="parameter">apc.coredump_unmap</code>
    <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>
   </dt>
   <dd>
    <span class="simpara">
     Разрешает APC перехватывать сигналы, такие как SIGSEGV, который записывает
     coredump, когда подан. Когда эти сигналы будут получены, APC попытается
     освободить всю разделяемую память, чтобы не включать её в coredump. Эта
     настройка может увеличить стабильность системы, когда критический сигнал был получен,
     а APC сконфигурирован на использование большого объёма памяти.
    </span>
    <div class="warning"><strong class="warning">Внимание</strong>
     <p class="simpara">
      Эта возможность потенциально опасна. Освобождение сегментов разделяемой
      памяти при получении критического сигнала может привести к непредсказуемому
      поведению.
     </p>
    </div>
    <blockquote class="note"><p><strong class="note">Замечание</strong>: 
     <span class="simpara">
      Хотя некоторые ядра предоставляют возможность игнорировать некоторые
      сегменты разделяемой памяти при записи core-файла, эти реализации
      могут также игнорировать важные сегменты памяти, такие как Apache scoreboard.
     </span>
    </p></blockquote>
   </dd>
  
  
   <dt id="ini.apcu.preload-path">
    <code class="parameter">apc.preload_path</code>
    <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
   </dt>
   <dd>
    <span class="simpara">
     Опционально. Задаёт путь, который используется APC для загрузки кешированных данных
     во время запуска.
    </span>
   </dd>
  

  
   <dt id="ini.apcu.use-request-time">
    <code class="parameter">apc.use_request_time</code>
    <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>
   </dt>
   <dd>
    <span class="simpara">
     Использовать время старта запроса <abbr title="Server Application Programming Interface">SAPI</abbr> для
     <abbr>TTL</abbr>.
    </span>
   </dd>
  
 </dl>
</div><?php manual_footer($setup); ?>