Принципы системыСтатья

Как SPG99 удерживает один DSN и не теряет состояние при остановке compute

Разбираем базовый принцип SPG99: стабильная точка входа, отдельный lifecycle worker и durable state вне compute. Именно это делает auto-start безопасным для приложения.

Опубликовано
14 марта 2026 г.
Обновлено
14 марта 2026 г.
Время чтения
7 мин
gatewaydurable storageautostartcontrol plane
Архитектура SPG99: Gateway, Control Plane, worker и durable storage
Схема показывает, как SPG99 разделяет стабильную точку входа, lifecycle compute и долговечное хранение состояния базы.

Стабильная точка входа

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

SPG99 держит эту точку входа отдельно от worker, который реально исполняет PostgreSQL-процессы. Для клиента это означает, что строка подключения не меняется каждый раз, когда compute был остановлен и затем поднят заново.

Для приложения это остаётся обычный PostgreSQL DSN
postgresql://user:password@gateway.spg99.ru:6432/appdb?sslmode=require

Durable state живёт вне worker

Если бы состояние базы жило только внутри текущего compute-узла, любая остановка worker означала бы риск потери данных или сложный процесс восстановления. Поэтому в SPG99 долговечное состояние базы отделено от текущего исполняющего узла.

Worker можно безопасно остановить, пересоздать или заменить, потому что источник истины для данных находится отдельно. Именно это делает auto-stop штатным состоянием архитектуры, а не опасным трюком для экономии бюджета.

Почему это важно

Остановка compute — это событие жизненного цикла, а не событие потери состояния. Для платформы это фундаментальное различие: оно определяет надёжность всей serverless-модели.

Что происходит при wake-up

Когда приходит первое подключение после периода idle, платформа не меняет DSN и не просит клиента искать новый endpoint. Вместо этого Gateway принимает соединение, Control Plane поднимает нужный compute, а затем трафик переводится в рабочее состояние.

С точки зрения приложения это выглядит как привычное подключение к PostgreSQL с тем лишь отличием, что после простоя нужно учитывать разумный connect_timeout и retry. Это ожидаемое поведение для любой системы с cold start.

Практика интеграции

Если приложение уже умеет корректно переживать кратковременные сетевые или инфраструктурные задержки, то wake-up SPG99 обычно не требует отдельной архитектурной переработки.

Что это даёт приложению и команде

Разделение entrypoint, lifecycle compute и durable storage даёт сразу несколько эффектов:

  • для приложения сохраняется обычная модель подключения к PostgreSQL;
  • команде не нужно вручную включать и выключать временные базы;
  • worker можно останавливать без смены DSN;
  • восстановление после idle становится управляемым и предсказуемым;
  • архитектура остаётся пригодной для automation через Console и API.

Именно поэтому SPG99 подходит не только как способ сэкономить, но и как способ убрать ручную эксплуатацию временных окружений.

Что почитать дальше

Что почитать дальше

Serverless PostgreSQLВебинар

Вебинар SPG99: PostgreSQL без оплаты простоя для dev/test, preview и внутренних сервисов

Это не общий разговор про облака и не обзор интерфейса. В эфире создадим базу в Console, подключимся через psql, посмотрим путь stopped → booting → ready, дадим базе уйти в idle и отдельно разберём контролируемое переключение между writer-профилями L1 и L2.

Эксплуатация и сценарии18 марта 2026 г.

Жизненный цикл базы в SPG99: active, idle, wake-up

Чтобы serverless-модель была удобной в эксплуатации, команда должна понимать не только выгоду, но и сами состояния базы. В SPG99 достаточно мыслить тремя режимами: active, idle и wake-up.