Files
frontend_react_fastapi/docker-compose.yml

172 lines
6.6 KiB
YAML
Raw Normal View History

2025-07-30 21:24:17 +08:00
services:
2025-08-01 10:47:02 +08:00
# db:
# image: postgres:17
# restart: always
# healthcheck:
# test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER} -d ${POSTGRES_DB}"]
# interval: 10s
# retries: 5
# start_period: 30s
# timeout: 10s
# volumes:
# - app-db-data:/var/lib/postgresql/data/pgdata
# env_file:
# - .env
# environment:
# - PGDATA=/var/lib/postgresql/data/pgdata
# - POSTGRES_PASSWORD=${POSTGRES_PASSWORD?Variable not set}
# - POSTGRES_USER=${POSTGRES_USER?Variable not set}
# - POSTGRES_DB=${POSTGRES_DB?Variable not set}
2025-07-30 21:24:17 +08:00
2025-08-01 10:47:02 +08:00
# adminer:
# image: adminer
# restart: always
# networks:
# - traefik-public
# - default
# depends_on:
# - db
# environment:
# - ADMINER_DESIGN=pepa-linha-dark
# labels:
# - traefik.enable=true
# - traefik.docker.network=traefik-public
# - traefik.constraint-label=traefik-public
# - traefik.http.routers.${STACK_NAME?Variable not set}-adminer-http.rule=Host(`adminer.${DOMAIN?Variable not set}`)
# - traefik.http.routers.${STACK_NAME?Variable not set}-adminer-http.entrypoints=http
# - traefik.http.routers.${STACK_NAME?Variable not set}-adminer-http.middlewares=https-redirect
# - traefik.http.routers.${STACK_NAME?Variable not set}-adminer-https.rule=Host(`adminer.${DOMAIN?Variable not set}`)
# - traefik.http.routers.${STACK_NAME?Variable not set}-adminer-https.entrypoints=https
# - traefik.http.routers.${STACK_NAME?Variable not set}-adminer-https.tls=true
# - traefik.http.routers.${STACK_NAME?Variable not set}-adminer-https.tls.certresolver=le
# - traefik.http.services.${STACK_NAME?Variable not set}-adminer.loadbalancer.server.port=8080
2025-07-30 21:24:17 +08:00
2025-08-01 10:47:02 +08:00
# prestart:
# image: '${DOCKER_IMAGE_BACKEND?Variable not set}:${TAG-latest}'
# build:
# context: ./backend
# networks:
# - traefik-public
# - default
# depends_on:
# db:
# condition: service_healthy
# restart: true
# command: bash scripts/prestart.sh
# env_file:
# - .env
# environment:
# - DOMAIN=${DOMAIN}
# - FRONTEND_HOST=${FRONTEND_HOST?Variable not set}
# - ENVIRONMENT=${ENVIRONMENT}
# - BACKEND_CORS_ORIGINS=${BACKEND_CORS_ORIGINS}
# - SECRET_KEY=${SECRET_KEY?Variable not set}
# - FIRST_SUPERUSER=${FIRST_SUPERUSER?Variable not set}
# - FIRST_SUPERUSER_PASSWORD=${FIRST_SUPERUSER_PASSWORD?Variable not set}
# - SMTP_HOST=${SMTP_HOST}
# - SMTP_USER=${SMTP_USER}
# - SMTP_PASSWORD=${SMTP_PASSWORD}
# - EMAILS_FROM_EMAIL=${EMAILS_FROM_EMAIL}
# - POSTGRES_SERVER=db
# - POSTGRES_PORT=${POSTGRES_PORT}
# - POSTGRES_DB=${POSTGRES_DB}
# - POSTGRES_USER=${POSTGRES_USER?Variable not set}
# - POSTGRES_PASSWORD=${POSTGRES_PASSWORD?Variable not set}
# - SENTRY_DSN=${SENTRY_DSN}
2025-07-30 21:24:17 +08:00
2025-08-01 10:47:02 +08:00
# backend:
# image: '${DOCKER_IMAGE_BACKEND?Variable not set}:${TAG-latest}'
# restart: always
# networks:
# - traefik-public
# - default
# depends_on:
# db:
# condition: service_healthy
# restart: true
# prestart:
# condition: service_completed_successfully
# env_file:
# - .env
# environment:
# - DOMAIN=${DOMAIN}
# - FRONTEND_HOST=${FRONTEND_HOST?Variable not set}
# - ENVIRONMENT=${ENVIRONMENT}
# - BACKEND_CORS_ORIGINS=${BACKEND_CORS_ORIGINS}
# - SECRET_KEY=${SECRET_KEY?Variable not set}
# - FIRST_SUPERUSER=${FIRST_SUPERUSER?Variable not set}
# - FIRST_SUPERUSER_PASSWORD=${FIRST_SUPERUSER_PASSWORD?Variable not set}
# - SMTP_HOST=${SMTP_HOST}
# - SMTP_USER=${SMTP_USER}
# - SMTP_PASSWORD=${SMTP_PASSWORD}
# - EMAILS_FROM_EMAIL=${EMAILS_FROM_EMAIL}
# - POSTGRES_SERVER=db
# - POSTGRES_PORT=${POSTGRES_PORT}
# - POSTGRES_DB=${POSTGRES_DB}
# - POSTGRES_USER=${POSTGRES_USER?Variable not set}
# - POSTGRES_PASSWORD=${POSTGRES_PASSWORD?Variable not set}
# - SENTRY_DSN=${SENTRY_DSN}
2025-07-30 21:24:17 +08:00
2025-08-01 10:47:02 +08:00
# healthcheck:
# test: ["CMD", "curl", "-f", "http://localhost:8000/api/v1/utils/health-check/"]
# interval: 10s
# timeout: 5s
# retries: 5
2025-07-30 21:24:17 +08:00
2025-08-01 10:47:02 +08:00
# build:
# context: ./backend
# labels:
# - traefik.enable=true
# - traefik.docker.network=traefik-public
# - traefik.constraint-label=traefik-public
2025-07-30 21:24:17 +08:00
2025-08-01 10:47:02 +08:00
# - traefik.http.services.${STACK_NAME?Variable not set}-backend.loadbalancer.server.port=8000
2025-07-30 21:24:17 +08:00
2025-08-01 10:47:02 +08:00
# - traefik.http.routers.${STACK_NAME?Variable not set}-backend-http.rule=Host(`api.${DOMAIN?Variable not set}`)
# - traefik.http.routers.${STACK_NAME?Variable not set}-backend-http.entrypoints=http
2025-07-30 21:24:17 +08:00
2025-08-01 10:47:02 +08:00
# - traefik.http.routers.${STACK_NAME?Variable not set}-backend-https.rule=Host(`api.${DOMAIN?Variable not set}`)
# - traefik.http.routers.${STACK_NAME?Variable not set}-backend-https.entrypoints=https
# - traefik.http.routers.${STACK_NAME?Variable not set}-backend-https.tls=true
# - traefik.http.routers.${STACK_NAME?Variable not set}-backend-https.tls.certresolver=le
2025-07-30 21:24:17 +08:00
2025-08-01 10:47:02 +08:00
# # Enable redirection for HTTP and HTTPS
# - traefik.http.routers.${STACK_NAME?Variable not set}-backend-http.middlewares=https-redirect
2025-07-30 21:24:17 +08:00
frontend:
image: '${DOCKER_IMAGE_FRONTEND?Variable not set}:${TAG-latest}'
restart: always
networks:
- traefik-public
- default
build:
context: ./frontend
args:
- VITE_API_URL=https://api.${DOMAIN?Variable not set}
- NODE_ENV=production
labels:
- traefik.enable=true
- traefik.docker.network=traefik-public
- traefik.constraint-label=traefik-public
- traefik.http.services.${STACK_NAME?Variable not set}-frontend.loadbalancer.server.port=80
- traefik.http.routers.${STACK_NAME?Variable not set}-frontend-http.rule=Host(`dashboard.${DOMAIN?Variable not set}`)
- traefik.http.routers.${STACK_NAME?Variable not set}-frontend-http.entrypoints=http
- traefik.http.routers.${STACK_NAME?Variable not set}-frontend-https.rule=Host(`dashboard.${DOMAIN?Variable not set}`)
- traefik.http.routers.${STACK_NAME?Variable not set}-frontend-https.entrypoints=https
- traefik.http.routers.${STACK_NAME?Variable not set}-frontend-https.tls=true
- traefik.http.routers.${STACK_NAME?Variable not set}-frontend-https.tls.certresolver=le
# Enable redirection for HTTP and HTTPS
- traefik.http.routers.${STACK_NAME?Variable not set}-frontend-http.middlewares=https-redirect
volumes:
app-db-data:
networks:
traefik-public:
# Allow setting it to false for testing
external: true