docs,refactor: readme docker-compose
This commit is contained in:
@@ -1,138 +1,138 @@
|
||||
services:
|
||||
|
||||
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}
|
||||
# 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}
|
||||
|
||||
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
|
||||
# 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
|
||||
|
||||
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}
|
||||
# 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}
|
||||
|
||||
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}
|
||||
# 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}
|
||||
|
||||
healthcheck:
|
||||
test: ["CMD", "curl", "-f", "http://localhost:8000/api/v1/utils/health-check/"]
|
||||
interval: 10s
|
||||
timeout: 5s
|
||||
retries: 5
|
||||
# healthcheck:
|
||||
# test: ["CMD", "curl", "-f", "http://localhost:8000/api/v1/utils/health-check/"]
|
||||
# interval: 10s
|
||||
# timeout: 5s
|
||||
# retries: 5
|
||||
|
||||
build:
|
||||
context: ./backend
|
||||
labels:
|
||||
- traefik.enable=true
|
||||
- traefik.docker.network=traefik-public
|
||||
- traefik.constraint-label=traefik-public
|
||||
# build:
|
||||
# context: ./backend
|
||||
# labels:
|
||||
# - traefik.enable=true
|
||||
# - traefik.docker.network=traefik-public
|
||||
# - traefik.constraint-label=traefik-public
|
||||
|
||||
- traefik.http.services.${STACK_NAME?Variable not set}-backend.loadbalancer.server.port=8000
|
||||
# - traefik.http.services.${STACK_NAME?Variable not set}-backend.loadbalancer.server.port=8000
|
||||
|
||||
- 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
|
||||
# - 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
|
||||
|
||||
- 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
|
||||
# - 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
|
||||
|
||||
# Enable redirection for HTTP and HTTPS
|
||||
- traefik.http.routers.${STACK_NAME?Variable not set}-backend-http.middlewares=https-redirect
|
||||
# # Enable redirection for HTTP and HTTPS
|
||||
# - traefik.http.routers.${STACK_NAME?Variable not set}-backend-http.middlewares=https-redirect
|
||||
|
||||
frontend:
|
||||
image: '${DOCKER_IMAGE_FRONTEND?Variable not set}:${TAG-latest}'
|
||||
|
||||
Reference in New Issue
Block a user