Настройка Opcache для кеширования скриптов, подтягиваем скорость

Периодически я возвращаюсь к вопросу настроек работы сервера, причем это может касаться и тех у кого виртуальный сервер и тех кто использует настоящий физический сервер. Работаю с разного рода хостингами уже давно и вопрос кеширования встал более остро, когда я стал арендовать в дата центре сервера. Они быстрые, сделаны на хорошем железе, имеют быстрые каналы, но настройка всегда была самым слабым местом, которое я не мог решить из за слабого набора знаний в этом. Я работал с разными специалистами и как правило все таки не всегда получал, что надо.

Причина думаю в том, что каждый хостинг или сервер имеет свои границы мощности, включая и оперативную память и iops жесткого диска и процессорную мощность. Но в общем решил постепенно разбираться и публиковать некоторые советы. Поэтому первая статья этого цикла посвящена настройке opcashe который создаёт кешированный пул php запросов, что актуально сегодня.

Что делает OPCACHE и для чего он

Opcashe применяется для создания опкодов. Опкодом называется результат компиляции файлов php. То есть выглядит это так:

  • Php компилирует файлы, которые необходимы по запросу
  • При компиляции извлекаются опкоды
  • После выполнения операции опкоды ликвидируются
  • Операция каждый раз повторяется

А если применить Opcashe на сервере то происходить это будет так

  • Php компилирует файлы, которые необходимы по запросу
  • При компиляции извлекаются опкоды, которые попадают в кеш opcashe
  • После выполнения операции опкоды остаются
  • Снижается время на запуск каждого скрипта

Отмечается во многих источниках, что снижается потраченное время на запуск скриптов php от 2 до 3 раз. Если учесть, что сейчас в сайтах все больше сложных скриптов, то тем более это важно. Есть даже мнение, что продолжительность временных затрат на запуск скриптов в cms системах может снизиться до 10 раз, за счет того, что целый блок операций, идущих друг за другом в данном случае снижают время выполнения за счет имеющегося опкода в кеше.

Как настроить и установить Opcache

Я рассмотрю основные моменты для установки и запуска этого кеширования на любом vps или выделенном сервере с установленной ISP manager, так как другими просто не пользуюсь. Но думаю имея навык для работы с другими панелями, вы можете также это php расширение установить. Для установки и включения заходим в работающую у нас версию php, если вы работаете на нескольких php, например 5.6 и php 7 то настроить надо для каждой и включаете это расширение.

Следующий этап самый важный, это отрегулировать и настроить использование этого кеша, так как идущие по умолчанию настройки могут не охватывать необходимый вам объём опкоде кеширования. Так например я при первом начале регулировки увидел, что у меня охвачено не более 14% скриптов этим кешированием, в ходе уже дальнейших несложных настроек смог довести до 88-90%. Конечно это снизило затраты производительности и улучшило скорость работы.

Для начала регулировки скачайте этот файл и назовите его opcashe.php после чего залейте в корень любого вашего сайта на vps или сервере. Скачать файл.

Затем запустите просмотр этого php файла и гляньте что у вас указано в настройках: opcache_hit_rate – процент использования opcashe и по использованию кеша исходя из оперативной памяти.

Настройка Opcache для кеширования скриптов, подтягиваем скорость

По умолчанию стоит количество 64 мегабайта оперативной памяти, что мне явно не хватало. Я после настроек сделал 1024 мегабайт, хотя думаю могло бы хватить даже 786, но памяти на серверах хватает, поэтому с запасом. В принципе по запущенному скрипту вы сможете сразу увидеть, сколько памяти занято, сколько свободно и пройдя в настройки php увеличить несколько параметров, которые вы видите на картинке ниже.

Настройка Opcache для кеширования скриптов, подтягиваем скорость

Основные настройки OPCACHE

Проверить настройки Opcashe можно разными способами. Если у вас ISP то легче всего зайти в настройки PHP и там вы увидите настройки, смотрим картинку ниже. Если у вас нет подключения нескольких php то файл конфигурации обычно располагается в /etc/php.d/opcache.ini. В настройках как правило основное что меняется, это несколько важных параметров.

opcache.memory_consumption=128 (количество оперативной памяти для opcashe, стоит по умолчанию 64, стоит пробовать и тестировать, до достижения оптимальных результатов)
opcache.interned_strings_buffer=8 (количество памяти для хранения строк в мегабайтах)
opcache.max_accelerated_files=4000 (количество скриптов, которые могут храниться в памяти opcashe, по умолчанию 2000)
opcache.revalidate_freq=60 (время в секундах для проверки валидации скриптов из памяти opcashe, некоторые ставят 5-10)
opcache.fast_shutdown=1 (включает или отключает возможность быстрого окончания последовательности ускоренного кода, добавляет вариант для работы Zend Engine Memory Management)
opcache.enable_cli=1 (включает или отключает работу Opcashe в CLI-версии PHP)

Весь список настроек OpcaChe

  • opcache.enable (значение по умолчанию 1) — включение/выключение OPcache.
    opcache.enable_cli (значение по умолчанию 0) — включение OPcache при вызове PHP из командной строки.
  • opcache.memory_consumption (значение по умолчанию 64) — размер используемой памяти (в мб.) для хранения прекомпилированного PHP-кода.
  • opcache.interned_strings_buffer (значение по умолчанию 4) — количество памяти для пула строк в мегабайтах.
  • opcache.max_accelerated_files (значение по умолчанию 2000) — максимальное количество ключей в хэш-таблице OPcache. Число должно быть простым и быть больше, чем те, что приведены в примере: 223, 463, 983, 1979, 3907, 7963, 16229, 32531, 65407, 130987, 262237, 524521, 1048793. Допустимы числа между 200 и 1000000.
  • opcache.max_wasted_percentage (значение по умолчанию 5) — максимальный процент замусоренной памяти для запланированного перезапуска.
  • opcache.use_cwd (значение по умолчанию 1) — при включении добавляет текущую рабочую директорию в ключ скрипта для предотвращения возникновения колизий между файлами с одинаковым именем.
  • opcache.validate_timestamps (значение по умолчанию 1) — появляется возможность обнуления OPcache вручную или перезапуском веб-сервера для того, чтобы привести в актуальное состояние данных об изменениях в файлах. Частота проверки управляется параметром opcache.revalidate_freq.
  • opcache.revalidate_freq (значение по умолчанию 2) — через какой промежуток времени (в секундах) проверять изменения временных меток для поддержания данных в памяти в актуальном состоянии, где 1 — проверка с периодичностью раз в секунду, 0 — постоянная проверка.
  • opcache.file_update_protection (значение по умолчанию 2) — предотвращает кэширование файлов, которые были изменены меньше, чем в указанное время (в секундах). Эта возможность защищает частично обновленные файлы от кэширования.
  • opcache.revalidate_path (значение по умолчанию 0) — включение или отключение оптимизации поиска файлов в include_path, если поиск файлов выключен и будет найден закэшированный файл, используемый в include_path, файл не будет найден повторно. Таким образом, если файл с именем, попадающийся где-либо еще в include_path, он не будет найден.
  • opcache.save_comments (значение по умолчанию 1) — если выключено, все комментарии PHPDoc будут удалены из кода с целью уменьшения размера оптимизированного кода. Не рекомендуется отключение этого параметра.
    opcache.load_comments (значение по умолчанию 1) — если выключено, то комментарии PHPDoc не будут загружаться из общей памяти.
    opcache.fast_shutdown (значение по умолчанию 0) — если включено, будет использоваться последовательность быстрых выключений для оптимизированного кода.
  • opcache.enable_file_override (значение по умолчанию 0) — при включении OPcache будет проверять наличие закэшированного файла при вызовах file_exists(), is_file() и is_readable().
  • opcache.optimization_level (значение по умолчанию 0xffffffff) — битовая маска, в которой каждый бит включает или отключает в соответствующие проходы OPcache.
    opcache.inherited_hack (значение по умолчанию 1) — включение этого хака при ошибках вида can’t redeclare class. По умолчанию возможность отключена, т.е оптимизация активирована. В PHP-5.3+ этот хак не требуется.
  • opcache.dups_fix (значение по умолчанию 0) — включайте при появлении ошибок вида Can’t redeclare class.
  • opcache.blacklist_filename — месторасположение списка файлов, к которым запрещен доступ для OPcache (поддерживаются маски). Каждый такой файл является текстовым файлом, в котором хранятся имена файлов, которые не требуется кэшировать, размещение имени каждого файла с отдельной строки. Имя файла может содержать полный путь, либо префикс.
  • opcache.max_file_size (значение по умолчанию 0) — позволяет исключать большие файлы из кэширования. По умолчанию кэшируются все файлы.
  • opcache.consistency_checks (значение по умолчанию 0) — проверять контрольную сумму кэша каждое N-ое количество запросов. По умолчанию параметр имеет значение 0, что отключает проверки. Подсчет контрольной суммы снижает производительность.
  • opcache.force_restart_timeout (значение по умолчанию 180) — время ожидания (в секундах) перед перезагрузкой в случае недоступности кэша. После истечение времени ожидания OPcache перезапускает процессы, которые были все это время заблокированы.
  • opcache.error_log — определение названия и местоположения лога ошибок OPcache. При пустом значении ошибки выводятся в консоль.
  • opcache.log_verbosity_level (значение по умолчанию 1) — все ошибки OPcache отправляет в лог-файл веб-сервера. По умолчанию логируются только критические ошибки (0) и обычные ошибки (1). Дополнительно можно включить предупреждения (2), информационные сообщения (3) или отладочную информацию (4).
  • opcache.preferred_memory_model — предпочитаемая модель общей памяти.
  • opcache.protect_memory (значение по умолчанию 0) — защита общей памяти от несанкционированной записи во время выполнения.
  • opcache.restrict_api (значение по умолчанию пустая строка) — разрешение вызова API-функций OPcache из PHP-скриптов, путь к которым начинается тем, что указано в строке. По умолчанию пустое значение означает запрет на все.

 

Выводы и итоги

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

В сравнении с более ранними расширениями кеширования opcashe является более удобным, тем более он вышел буквально несколько лет назад, но есть ограничение, что он поддерживает php только с 5.5 версии. Поэтому если у вас более ранняя версия php вполне желательно перейти на новую, тем более есть даже в самом переходе значительный ресурс скорости работы сайта.

2 КОММЕНТАРИИ

  1. Спасибо. Вечно пишу это место не так. Ищу когда плагин с этим словом, тоже все не ту букву ставлю. Ассоциативный ряд где то спутался)

    Надеюсь статья пригодилась.

ОСТАВЬТЕ ОТВЕТ

Пожалуйста, введите ваш комментарий!
пожалуйста, введите ваше имя здесь

СЕГОДНЯ ЧИТАЮТ

Как закалялась Instantcms – развитие и потеря аудитории

Эта история всё-таки должна сохраниться и поэтому я решил написать некоторую историю как развивалась, прошла свой расцвет и увяла в принципе...

Интервью с Олегом: Информационные сайты, поиск ниши и старт в будущее

Сегодня наше интервью по большей части посвящено работу с информационными сайтами. Олег web разработчик, который создаёт собственные проекты и работает с ними. Что он...

Лучшие 5 плагинов для поиска на сайте WordPress, обзор и описание

Думаете об улучшении поисковых запросов на вашем сайте WordPress? Мощные поисковые плагины - лучший способ сделать это. По умолчанию WordPress включает функцию поиска, но она довольно...

Установка и настройка сервера Soyoustart – полная пошаговая инструкция

Сегодня мы изучим как настроить и установить сервер взятый в аренду на одном из крупнейших провайдеров выделенных серверов soyoustart который является частью крупного сервер...

Обновление WordPress 4.8.2, описание релиза

Как то быстро так вышло обновление Wordpress 4.8.2. Как и свойственно вордпрессу обновление прошло за 20 секунд, без каких либо проблем. Последнее у меня...

Лучшие варианты SEO плагинов для WordPress, практический обзор и сравнение 2019

Работа с SEO в Wordpress достаточно простая, но в то же время достаточно насыщенная по деталям. Каждый заинтересован в поисковом продвижении своего сайта, но...

ПОХОЖИЕ МАТЕРИАЛЫ

10 причин открытия интернет-магазина для малого и среднего бизнеса

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

10 плагинов WordPress для создания форума: настройка, описание и управление

Онлайн форумы или доски объявлений безумно популярны среди пользователей всех видов, уровней знаний и интересов. Просто подумай об этом. У вас есть вопрос об...

Улучшения и дополнения в WordPress 5.5 (Возможности и скриншоты)

Выпущена бета-версия WordPress 5.5, выход которой запланирован на 11 августа 2020 года. Это будет второй по значимости выпуск WordPress в этом году, и он...

Jetpack 8.7 добавляет функцию развертывания Tweetstorm, улучшает настройку поиска

Jetpack 8.7 был выпущен на этой неделе с потрясающей новой функцией, которая позволяет пользователям «развернуть» твитторм и опубликовать его в посте. Функция работает внутри блока Tweet. После...

Обзор улучшений и изменений в редакторе Gutenberg 8.5

Gutenberg 8.5 добавляет редактирование изображений из одной галереи, позволяет загружать изображения из внешних источников и улучшает перетаскивание. Команда Гутенберга выпустила версию 8.5 своего плагина для общественности. Это...

Установка, настройка, оформление темы Woodmart – учимся ставить на сайт

Многие работают с темой Woodmart, которая является одной из лучших тем для создания интернет магазина. Поэтому я делаю статью инструкцию по вопросам и ответам...