Repo passa a viver dentro de infra/, com três stacks isoladas que
compartilham uma network Docker externa ('infra-net'):
main/ infra base: postgres + redis + minio + minio-init + pgadmin
+ caddy. Postgres roda em modo multi-banco; o init script
cria os DBs 'wedding' e 'gitea' com roles dedicadas. MinIO
tem um bucket inicial criado pelo minio-init com anonymous
download + CORS. Caddy é o único container expondo 80/443
e roteia por hostname: gitea.{DOMAIN_BASE} / wedding.* /
pgadmin.* / minio.* / media.* (rewrite de bucket).
gitea/ gitea + act_runner. Gitea liga no postgres compartilhado e
usa redis pra cache+sessões. O runner ganha um Dockerfile
pequeno que adiciona docker CLI por cima do
gitea/act_runner pra workflows poderem chamar 'docker
build'. Bootstrap do token de runner documentado no
.env.example.
wedding_photo/ Só a aplicação: 'wedding_app' (FastAPI + SPA) +
postgres-backup + media-backup. Os bancos e o MinIO vêm
da stack main/. A app usa extra_hosts: host-gateway pra
alcançar media.{DOMAIN_BASE} via Caddy mesmo em dev local
— assim a assinatura S3 fecha com o host que o browser
usa pra fazer PUT.
Orquestração:
- Makefile no root: 'make up' sobe tudo na ordem (main -> gitea ->
wedding_photo). 'make up-{main,gitea,wedding}' pra controle
granular. 'make logs-*', 'make down', 'make status', 'make pull-*'.
- network.sh cria a 'infra-net' antes de qualquer up; idempotente.
- Cada stack tem seu próprio .env.example. As creds compartilhadas
(DOMAIN_BASE, MINIO_ROOT_*, WEDDING_DB_*) precisam casar entre
main/.env e o consumidor (gitea/.env ou wedding_photo/.env).
- .gitignore ignora todas as pastas data/ dos volumes.
83 lines
2.0 KiB
Makefile
83 lines
2.0 KiB
Makefile
.PHONY: help network up down restart status \
|
|
up-main up-gitea up-wedding \
|
|
down-main down-gitea down-wedding \
|
|
logs-main logs-gitea logs-wedding \
|
|
pull-main pull-gitea pull-wedding \
|
|
rebuild-wedding
|
|
|
|
NET := infra-net
|
|
DC_MAIN := docker compose -f infra/main/docker-compose.yml --env-file infra/main/.env
|
|
DC_GITEA := docker compose -f infra/gitea/docker-compose.yml --env-file infra/gitea/.env
|
|
DC_WEDDING := docker compose -f infra/wedding_photo/docker-compose.yml --env-file infra/wedding_photo/.env
|
|
|
|
help:
|
|
@echo "Stacks: main (postgres+redis+minio+pgadmin+caddy) | gitea | wedding_photo"
|
|
@echo ""
|
|
@echo " make up Sobe tudo na ordem (main -> gitea -> wedding)"
|
|
@echo " make down Desce tudo na ordem inversa"
|
|
@echo " make restart down + up"
|
|
@echo " make status ps de todas as stacks"
|
|
@echo ""
|
|
@echo " make up-main Sobe só a stack main"
|
|
@echo " make up-gitea Sobe só o gitea"
|
|
@echo " make up-wedding Build + up do app wedding"
|
|
@echo " make rebuild-wedding Force rebuild do app wedding"
|
|
@echo " make down-{main,gitea,wedding}"
|
|
@echo " make logs-{main,gitea,wedding}"
|
|
@echo " make pull-{main,gitea,wedding}"
|
|
@echo " make network Cria a network external '$(NET)' (idempotente)"
|
|
|
|
network:
|
|
@./network.sh
|
|
|
|
up: network up-main up-gitea up-wedding
|
|
|
|
down: down-wedding down-gitea down-main
|
|
|
|
restart: down up
|
|
|
|
status:
|
|
@$(DC_MAIN) ps || true
|
|
@$(DC_GITEA) ps || true
|
|
@$(DC_WEDDING) ps || true
|
|
|
|
up-main: network
|
|
$(DC_MAIN) up -d
|
|
|
|
up-gitea: network
|
|
$(DC_GITEA) up -d
|
|
|
|
up-wedding: network
|
|
$(DC_WEDDING) up -d --build
|
|
|
|
rebuild-wedding: network
|
|
$(DC_WEDDING) build --no-cache
|
|
$(DC_WEDDING) up -d
|
|
|
|
down-main:
|
|
$(DC_MAIN) down
|
|
|
|
down-gitea:
|
|
$(DC_GITEA) down
|
|
|
|
down-wedding:
|
|
$(DC_WEDDING) down
|
|
|
|
logs-main:
|
|
$(DC_MAIN) logs -f
|
|
|
|
logs-gitea:
|
|
$(DC_GITEA) logs -f
|
|
|
|
logs-wedding:
|
|
$(DC_WEDDING) logs -f
|
|
|
|
pull-main:
|
|
$(DC_MAIN) pull
|
|
|
|
pull-gitea:
|
|
$(DC_GITEA) pull
|
|
|
|
pull-wedding:
|
|
$(DC_WEDDING) pull
|