Развертывание
Документ описывает продакшен-запуск после разделения проекта на backend, frontend и worker.
Перед стартом заполните минимальный .env по configuration.md. Полный справочник переменных лежит в configuration/env-vars.md; после первого входа большинство продуктовых настроек удобнее менять через Web App админку.
Быстрый старт
Заголовок раздела «Быстрый старт»Обычный docker compose up -d --build поднимает:
postgresиredisс проверками здоровья;migrateкак одноразовый сервис на backend-образе;backendтолько после успешных миграций;workerтолько после успешных миграций;frontendкак отдельный nginx-образ без Python runtime.
Основной путь миграций — отдельный сервис migrate. backend и worker также выполняют
безопасную проверку схемы на старте под PostgreSQL advisory lock, поэтому прямой запуск сервиса
без compose тоже применит недостающие миграции и не создаст гонку на схеме БД.
Готовые папки запуска
Заголовок раздела «Готовые папки запуска»Для продакшена удобнее использовать не корневой compose, а отдельные Docker Compose-примеры из папки deploy/examples. В каждой папке лежат свой docker-compose.yml, .env.example и нужный конфиг прокси.
Предпочтительный вариант для обычного публичного сервера - Caddy: он сам выпускает и продлевает HTTPS-сертификаты, а конфигурация получается короче, чем с ручным Nginx.
| Папка | Когда использовать |
|---|---|
deploy/examples/caddy | Нужен простой публичный HTTPS с автоматическими сертификатами Let’s Encrypt. |
deploy/examples/nginx | Уже используете Nginx и готовы положить TLS-сертификаты рядом с примером. |
deploy/examples/newt | Публикуете сервисы через Pangolin/Newt без входящих портов на сервере приложения. |
deploy/examples/no-proxy | Нужно напрямую открыть HTTP-порты backend/frontend или проверить стек за внешним TLS-терминатором. |
Caddy (рекомендуемый вариант)
Заголовок раздела «Caddy (рекомендуемый вариант)»Caddy подходит, если DNS-записи WEBHOOK_HOST и MINIAPP_HOST смотрят на сервер приложения, а входящие 80/tcp и 443/tcp открыты.
Минимально поменяйте в .env:
WEBHOOK_HOSTиMINIAPP_HOST;BOT_TOKEN,ADMIN_IDS;POSTGRES_PASSWORD;WEBAPP_SESSION_SECRET,WEBHOOK_SECRET_TOKEN;PANEL_API_URL,PANEL_API_KEY,PANEL_WEBHOOK_SECRET.
Если нужна нестандартная логика Caddy, правьте Caddyfile рядом с compose и перезапускайте:
Nginx-вариант поднимает Nginx в той же Docker-сети, что и приложение:
WEBHOOK_HOSTпроксируется вbackend:8080;MINIAPP_HOSTпроксируется вfrontend:80;frontendсам проксирует внутренние/api,/authи ассеты тем вbackend:8081.
Положите TLS-сертификаты в ssl/:
Имена папок должны совпадать с WEBHOOK_HOST и MINIAPP_HOST в .env.
Если нужно поменять заголовки, лимиты или TLS-настройки, правьте nginx.conf.template и перезапускайте Nginx:
Pangolin / Newt
Заголовок раздела «Pangolin / Newt»Этот вариант не открывает входящие порты на сервере приложения. Newt подключается к Pangolin, а публичные домены настраиваются ресурсами в панели Pangolin.
В .env заполните:
WEBHOOK_HOSTиMINIAPP_HOST- публичные домены ресурсов в Pangolin;PANGOLIN_ENDPOINT,NEWT_ID,NEWT_SECRET- значения из настроек site/client в Pangolin;- обычные переменные приложения:
BOT_TOKEN,ADMIN_IDS,POSTGRES_PASSWORD, секреты и доступ к Remnawave.
В Pangolin создайте два HTTP-ресурса для этого Newt site:
| Публичный домен | Upstream |
|---|---|
https://webhooks.example.com | http://backend:8080 |
https://app.example.com | http://frontend:80 |
Проверка:
Без обратного прокси
Заголовок раздела «Без обратного прокси»Этот вариант напрямую публикует два HTTP-порта:
- backend/вебхуки:
WEB_SERVER_BIND, по умолчанию0.0.0.0:8080; - frontend/Mini App:
FRONTEND_BIND, по умолчанию0.0.0.0:8082.
Важно: контейнеры приложения сами не выпускают TLS-сертификаты. Для реального вебхука Telegram и Mini App публичные URL должны быть HTTPS. Используйте этот вариант для локальной проверки, внутренней сети или ситуации, когда HTTPS завершается внешней платформой и дальше трафик приходит на эти порты.
Проверка локально:
Корневой docker-compose.yml оставлен для локальной сборки из исходников. Примеры в deploy/examples используют готовые GHCR-образы и не требуют указывать -f.
Миграции
Заголовок раздела «Миграции»При обычном старте миграции применяются автоматически:
Для ручного повторного запуска:
Проверить логи миграций:
backend и worker зависят от migrate через service_completed_successfully; если миграции
падают, приложение не стартует поверх неподготовленной БД. При прямом запуске backend или
worker без compose тот же init_db применяет недостающие миграции перед стартом логики сервиса.
Сервисы
Заголовок раздела «Сервисы»backend: aiohttp API, вебхук Telegram, платежные вебхуки, вебхуки панели, проверка здоровья/healthz.worker: TariffTrafficWorker, задачи синхронизации с панелью, обработка рассылок, потребители очереди вебхуков.frontend: статические Svelte-ассеты через nginx.postgres: PostgreSQL 17.redis: Redis 7 для FSM, кеша, rate-limit, очередей и locks.
В продакшен-примерах внешний доступ добавляют caddy, nginx, newt или прямые ports в соответствующем варианте из deploy/examples.
Логи и проверка
Заголовок раздела «Логи и проверка»Эндпоинты проверки здоровья:
В обычном compose backend публикуется на 127.0.0.1:${WEB_SERVER_PORT:-8080}, frontend на
127.0.0.1:${FRONTEND_PORT:-8082}. В новых продакшен-примерах проверяйте bind-переменные
конкретной папки: HTTP_BIND, HTTPS_BIND, WEB_SERVER_BIND или FRONTEND_BIND.
Обновление
Заголовок раздела «Обновление»Локальная сборка из репозитория:
Если нужно пересобрать только образы приложения:
Образы GHCR и Docker Hub
Заголовок раздела «Образы GHCR и Docker Hub»Образы приложения называются единообразно:
Чтобы собрать и сразу опубликовать все три образа в GHCR и Docker Hub, сначала выполните логин в оба registry:
PowerShell-вариант:
По умолчанию скрипты используют:
IMAGE_REGISTRIES=ghcr.io docker.ioIMAGE_NAMESPACE=3252a8IMAGE_PREFIX=remnawave-minishopTARGETS=backend worker frontendDOCKERFILE=deploy/docker/Dockerfile
Если нужен только один registry или другой namespace, переопределите переменные:
Старые раздельные команды тоже остаются:
Для PowerShell есть варианты scripts/docker-build-images.ps1 и
scripts/docker-push-images.ps1. Если публикуете образы в другой registry, namespace или с другим
префиксом имени, переопределите IMAGE_NAMESPACE, IMAGE_REGISTRY или IMAGE_PREFIX.
Для совместимости оставлены Docker Hub-only скрипты:
PowerShell-вариант:
Если PowerShell блокирует локальные скрипты ошибкой PSSecurityException / Execution Policy,
запустите те же скрипты с обходом политики только для текущего процесса:
Этот bypass действует только для запущенного процесса powershell и не меняет системную политику.
Масштабирование
Заголовок раздела «Масштабирование»В текущих Compose-файлах заданы явные container_name, поэтому docker compose --scale для
backend, frontend и worker не используется: Docker не может создать несколько контейнеров с
одним именем. Если понадобится горизонтальное масштабирование, уберите container_name у
масштабируемых сервисов или перенесите конфигурацию в orchestrator.
Состояние FSM, rate-limit и краткоживущие кеши вынесены в Redis, а tariff tick защищен Redis distributed lock; код подготовлен к нескольким репликам, но текущие Compose-файлы ориентированы на фиксированные имена контейнеров.
Данные и volumes
Заголовок раздела «Данные и volumes»Продакшен compose использует именованные volumes:
postgres-data;redis-data;shop-data; В Caddy-варианте также используютсяcaddy-dataиcaddy-config.
shop-data монтируется целиком в /app/data; внутри него лежат тарифы, темы, логотипы и прочие
файловые данные приложения.
Если вместо именованного volume включаете bind mount ./data:/app/data, на сервере заранее дайте права
пользователю контейнера 10001:
Проверка прав:
Резервная копия PostgreSQL
Заголовок раздела «Резервная копия PostgreSQL»Восстановление в чистую БД:
Обратный прокси
Заголовок раздела «Обратный прокси»Готовые reverse-proxy примеры описаны выше:
- Caddy - автоматический HTTPS;
- Nginx - сертификаты кладутся рядом в
ssl/; - Newt/Pangolin - без входящих портов на сервере приложения.
Во всех вариантах схема одинаковая:
- webhook/backend-домен целиком идет в
backend:8080; - Mini App/frontend-домен целиком идет в
frontend:80; - API/auth/theme routes Mini App дальше проксируются frontend nginx в
backend:8081.
Минимальная логика Caddy:
Минимальная логика Nginx такая же: webhooks.example.com проксируется в backend:8080,
app.example.com - в frontend:80. В deploy/examples/nginx/nginx.conf.template уже есть
заголовки X-Forwarded-*, редирект HTTP -> HTTPS и пути сертификатов.
Переменный env-файл
Заголовок раздела «Переменный env-файл»По умолчанию compose читает .env. Для smoke-тестов или отдельного окружения можно подставить
другой файл: