Сборка и требования
Требования:
- Go 1.26+
- PostgreSQL, Redis
- Make
Локальная сборка
# Установка зависимостей
go mod download
# Линт/тест/сборка
go vet ./...
go test ./... -race
go build ./...Линтеры
Используется golangci-lint v2.10.1 с дополнительными линтерами:
# Установка
make install-lint
# Полный прогон
make lint
# Быстрый (только app + domain)
make lint-fast
# Архитектурная проверка (domain не импортирует infra/app)
make lint-archВключены линтеры: gosec (безопасность), bodyclose (закрытие тел HTTP-ответов), noctx (передача context в HTTP-запросы). Конфигурация — .golangci.yml.
Сканирование уязвимостей
make vulncheckЗапускает govulncheck ./... — проверяет зависимости на известные CVE.
CI (.gitlab-ci.yml)
Этапы пайплайна:
| Этап | Job | Когда |
|---|---|---|
check | lint (golangci-lint), docs (redocly), test (go test + coverage), integration (Postgres+Redis) | Каждый push |
security | govulncheck | Каждый push |
build | build (go build) | Push без тега |
build | build-release (bundle + upload в Package Registry) | Push с тегом |
На push с тегом job build-release собирает deployment-бандл и загружает его в GitLab Package Registry (Generic Packages).
Deployment Bundle
Бандл — самодостаточный архив для деплоя на сервер (Go на сервере не нужен):
# Для текущей ОС
make bundle
# Для Linux (серверы)
make bundle-linux
# С явной версией
VERSION=1.2.3 make bundle
# Произвольная платформа
make bundle GOOS=linux GOARCH=arm64Содержимое бандла:
marv-VERSION-OS-ARCH/
├── bin/
│ ├── marv # основной сервер
│ ├── hgoose # утилита миграций БД (goose v3)
│ └── config-migrator # конвертер legacy-конфигов
├── scripts/
│ ├── deploy.sh # управление (run, migrate, version, ...)
│ └── marv.service.template # шаблон systemd unit
├── migrations/
│ └── *.sql # SQL-миграции
└── config/
├── config.example.yml # пример конфигурации
├── bots.example.json # пример конфигурации ботов
├── products.example.json # пример конфигурации продуктов
└── .env.example # пример переменных окруженияПараметры сборки:
CGO_ENABLED=0— статическая линковка-tags=go_json— ускоренный JSON через go_json-ldflags="-s -w -X ...AppVersion=VERSION"— инъекция версии, strip debug info
Деплой на сервер
Деплой выполняется через Game Repository — см. Game Repository workflow.
Там описаны: создание Deploy Token, настройка сервера, marv-ctl.sh, обновление версии и конфигов.
deploy.sh
Скрипт-помощник для управления бандлом на сервере. Входит в состав бандла.
| Команда | Описание |
|---|---|
migrate | Применить все миграции |
migrate-status | Статус миграций |
migrate-down | Откатить одну миграцию |
config-migrate <file> | Мигрировать legacy-конфиг в новый формат |
run | Запустить сервер (GIN_MODE=release) |
version | Версия бинарников |
./scripts/deploy.sh migrate # миграции
./scripts/deploy.sh run # запуск
./scripts/deploy.sh version # версияDocker
Dockerfile (multi-stage build):
# Сборка образа
docker build -t marv:latest --build-arg VERSION=1.2.3 .
# Запуск
docker run -p 8080:8080 -v ./config:/app/config marv:latestDocker Compose (локальная разработка):
docker-compose up -dПоднимает marv + PostgreSQL 17 + Redis 7 с health-checks и пробросом портов.
Запуск
# Из исходников
go run ./cmd/marv
# Из бинарника
./marvПеред деплоем:
- Применить миграции (
hgoose upили./scripts/deploy.sh migrate) - Заполнить конфиг или переменные окружения
- Dev: PostgreSQL и Redis локальные. Release: PostgreSQL — отдельный сервер, Redis — обычно локальный
