<b>Octane ускоряет Laravel, но ломается там, где код писали под «каждый запрос заново»</b>
Главная ловушка — состояние. Всё, что живёт в singleton, статике, глобальном helper-кэше или замыкании контейнера, может пережить запрос и утащить за собой старые данные. Проверяйте сервисы на утечки: не храните user context, tenant, request, locale и connection state дольше одного цикла.
Вторая зона риска — фасады, события и сторонние пакеты. Если пакет внутри держит mutable-объект или полагается на сброс локального кэша между запросами, под Octane он начинает «плавать». Отдельно смотрите на очереди, транзакции и авторизацию: после warm-up они должны работать так же, как в обычном PHP-FPM.
Практика простая: убирайте состояние в request-scoped объекты, очищайте кеши в terminate/hook, не используйте static для бизнес-логики и прогоняйте нагрузочный сценарий с повторяющимися пользователями, а не только с «пустыми» запросами. Если баг исчезает после перезапуска воркера — это почти всегда намёк на утечку состояния.
Octane даёт прирост только тем проектам, где код написан как stateless. Сначала чините границы состояния, потом включайте ускорение — иначе вы просто ускорите воспроизведение багов.
Laravel & PHP Deep — фреймворки и пакеты
@laravel_php_deep
<b>Octane ускоряет Laravel, но ломается там, где код писали под «каждый запрос заново»</b>
Этот пост опубликован в Telegram-канале Laravel & PHP Deep — фреймворки и пакеты. Подписаться можно по ссылке: @laravel_php_deep.