2026-04-06 15:43:45 +03:00
# Worker и запуск
## Entrypoint (`worker.php` приложения)
2026-04-23 17:39:01 +03:00
Фреймворк запускается удобным для пользователя способом. `WorkerRunner::run()` без аргументов обрабатывает один запрос и завершается (классический SAPI/FPM/CGI). Чтобы крутить worker-петлю, приложение передаёт свой адаптер:
2026-04-06 15:43:45 +03:00
```php
use Pronchev\Pinecore\Kernel;
use Pronchev\Pinecore\Http\WorkerRunner;
require __DIR __ . '/vendor/autoload.php';
Kernel::boot(__DIR__);
2026-04-23 17:39:01 +03:00
$runner = Kernel::container()->get(WorkerRunner::class);
// Один запрос:
$runner->run();
// Или worker-петля (пример для FrankenPHP):
$runner->run(fn ($handler) => frankenphp_handle_request($handler));
2026-04-06 15:43:45 +03:00
```
2026-04-23 17:39:01 +03:00
Адаптер получает `callable $handler` (обработать один запрос) и возвращает `bool` — продолжать ли цикл. `MAX_REQUESTS` , `$app->terminate()` и `gc_collect_cycles()` отрабатывает сам `WorkerRunner` между итерациями. `WorkerRunner` резолвится через DI autowiring — конфигурировать не нужно.
2026-04-06 15:43:45 +03:00
## WorkerRunner (`src/Http/WorkerRunner.php`)
```php
final class WorkerRunner
{
public function __construct(
private readonly HttpApplication $app,
private readonly ExceptionHandler $exceptionHandler,
) {}
2026-04-23 17:39:01 +03:00
public function run(?callable $loop = null): void
2026-04-06 15:43:45 +03:00
{
2026-04-23 17:39:01 +03:00
if ($loop === null) {
$this->handle();
$this->app->terminate();
return;
}
$handler = fn () => $this->handle();
2026-04-06 15:43:45 +03:00
$maxRequests = (int) ($_SERVER['MAX_REQUESTS'] ?? 0); // 0 = без лимита
for ($n = 0; !$maxRequests || $n < $maxRequests; ++$n) {
2026-04-23 17:39:01 +03:00
$keepRunning = $loop($handler);
2026-04-06 15:43:45 +03:00
$this->app->terminate(); // хук: закрытие ресурсов (сейчас пустой)
gc_collect_cycles();
2026-04-23 17:39:01 +03:00
if (!$keepRunning) break;
}
}
private function handle(): void
{
try {
$this->app->handleRequest($_GET, $_POST, $_COOKIE, $_FILES, $_SERVER);
} catch (\Throwable $e) {
$this->exceptionHandler->handleException($e); // critical лог
2026-04-06 15:43:45 +03:00
}
}
}
```
## Env-переменные
| Переменная | По умолчанию | Описание |
|---|---|---|
| `APP_ENV` | `dev` | Среда исполнения |
| `MAX_REQUESTS` | `0` | Лимит запросов на воркер (0 = без лимита) |
| `LOG_LEVEL` | `debug` | Минимальный уровень логирования |
| `LOG_FILE` | — | Путь к файлу лога (активирует FileLogger) |
| `JWT_SECRET` | обязателен | HMAC-ключ для JWT |