Как сделать сервер artisan многопоточным?
Когда речь заходит о запуске приложения в локальной среде, многие из нас прибегают к удобному инструменту – встроенному веб-серверу, доступному через php -S
или artisan serve
. Этот инструмент является прекрасным выбором для множества проектов, но он обладает своими особенностями, о которых важно помнить.
Одна из ключевых ограничений встроенного веб-сервера PHP заключается в том, что он оперирует только одним однопоточным процессом. Это значит, что приложение будет отдавать ответы одним за другим, и если будет “тяжёлый” запрос, то следующие после него запросы будут ожидать его выполнения. Это может стать проблемой, особенно если ваше приложение использует технологии, требующие одновременного обслуживания нескольких соединений, такие как SSE (Server-Sent Events).
Однако, не стоит отчаиваться и сразу устанавливать решения типа nginx. У PHP есть решение этой проблемы, которое доступно с версии 7.4.0, выпущенной еще в 2019 году.
Секрет заключается в использовании переменной окружения PHP_CLI_SERVER_WORKERS
, которая позволяет указать количество воркеров для веб-сервера PHP.
Для пользователей фреймворка Laravel этот процесс очень прост, требуется только добавить значение в файл .env
, например:
PHP_CLI_SERVER_WORKERS=4
APP_NAME="Laravel.su"
APP_ENV=local
APP_KEY=XXX-XXX-XXX
Однако, стоит отметить, что этот метод не будет работать для пользователей Windows. В этом случае вам придется прибегнуть к другим методам оптимизации производительности.
Сейчас (март 2024) переменная PHP_CLI_SERVER_WORKERS
попрежнему считается экспериментальной, но я надеюсь, что она лишится этого статуса и будет с нами на постоянной основе.