Files

172 lines
6.3 KiB
YAML
Raw Permalink Normal View History

2020-04-19 16:44:12 +02:00
services:
2020-04-19 16:44:12 +02:00
db:
2025-04-30 09:32:13 +02:00
image: postgres:17
restart: always
2024-09-16 21:52:33 +02:00
healthcheck:
test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER} -d ${POSTGRES_DB}"]
interval: 10s
retries: 5
start_period: 30s
timeout: 10s
2020-04-19 16:44:12 +02:00
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}
2020-04-19 16:44:12 +02:00
2024-03-12 18:30:54 +01:00
adminer:
image: adminer
restart: always
2020-04-19 16:44:12 +02:00
networks:
2024-03-09 01:41:13 +01:00
- traefik-public
2020-04-19 16:44:12 +02:00
- default
depends_on:
- db
environment:
2024-03-12 18:30:54 +01:00
- ADMINER_DESIGN=pepa-linha-dark
labels:
- traefik.enable=true
2024-03-09 01:41:13 +01:00
- traefik.docker.network=traefik-public
- traefik.constraint-label=traefik-public
2024-03-12 18:30:54 +01:00
- 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
2020-04-19 16:44:12 +02: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}
2020-04-19 16:44:12 +02:00
backend:
image: '${DOCKER_IMAGE_BACKEND?Variable not set}:${TAG-latest}'
restart: always
2024-03-09 01:41:13 +01:00
networks:
- traefik-public
- default
2020-04-19 16:44:12 +02:00
depends_on:
2024-09-16 21:52:33 +02:00
db:
condition: service_healthy
restart: true
prestart:
condition: service_completed_successfully
2020-04-19 16:44:12 +02:00
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}
2020-04-19 16:44:12 +02:00
- SMTP_HOST=${SMTP_HOST}
- SMTP_USER=${SMTP_USER}
- SMTP_PASSWORD=${SMTP_PASSWORD}
- EMAILS_FROM_EMAIL=${EMAILS_FROM_EMAIL}
- POSTGRES_SERVER=db
2024-03-12 14:39:53 +01:00
- 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}
2024-09-12 15:21:24 +02:00
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:8000/api/v1/utils/health-check/"]
2024-09-12 15:21:24 +02:00
interval: 10s
timeout: 5s
retries: 5
2020-04-19 16:44:12 +02:00
build:
context: ./backend
labels:
- traefik.enable=true
2024-03-09 01:41:13 +01:00
- traefik.docker.network=traefik-public
- traefik.constraint-label=traefik-public
- traefik.http.services.${STACK_NAME?Variable not set}-backend.loadbalancer.server.port=8000
2024-02-25 19:39:33 +01:00
- traefik.http.routers.${STACK_NAME?Variable not set}-backend-http.rule=Host(`api.${DOMAIN?Variable not set}`)
2024-03-09 01:41:13 +01:00
- traefik.http.routers.${STACK_NAME?Variable not set}-backend-http.entrypoints=http
- traefik.http.routers.${STACK_NAME?Variable not set}-backend-https.rule=Host(`api.${DOMAIN?Variable not set}`)
2024-03-09 01:41:13 +01:00
- 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-12-18 09:40:41 +08:00
# 为 HTTP 和 HTTPS 启用重定向
- traefik.http.routers.${STACK_NAME?Variable not set}-backend-http.middlewares=https-redirect
2024-02-25 19:39:33 +01:00
2020-04-19 16:44:12 +02:00
frontend:
image: '${DOCKER_IMAGE_FRONTEND?Variable not set}:${TAG-latest}'
restart: always
2024-03-09 01:41:13 +01:00
networks:
- traefik-public
- default
2020-04-19 16:44:12 +02:00
build:
2024-03-08 19:23:54 +01:00
context: ./frontend
2024-03-09 01:41:13 +01:00
args:
- VITE_API_URL=https://api.${DOMAIN?Variable not set}
2024-03-09 01:41:13 +01:00
- 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}`)
2024-03-09 01:41:13 +01:00
- 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}`)
2024-03-09 01:41:13 +01:00
- 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
2020-04-19 16:44:12 +02:00
2025-12-18 09:40:41 +08:00
# 为 HTTP 和 HTTPS 启用重定向
- traefik.http.routers.${STACK_NAME?Variable not set}-frontend-http.middlewares=https-redirect
2020-04-19 16:44:12 +02:00
volumes:
app-db-data:
networks:
traefik-public:
2025-12-18 09:40:41 +08:00
# 允许在测试时将其设置为 false
2024-03-09 01:41:13 +01:00
external: true