services: postgres: image: postgres:16 container_name: toir-postgres restart: unless-stopped environment: POSTGRES_USER: ${POSTGRES_USER:-postgres} POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-change-me} POSTGRES_DB: ${POSTGRES_DB:-toir} healthcheck: test: [ "CMD-SHELL", "pg_isready -U ${POSTGRES_USER:-postgres} -d ${POSTGRES_DB:-toir}", ] interval: 10s timeout: 5s retries: 5 start_period: 10s volumes: - postgres-data:/var/lib/postgresql/data networks: - toir server: build: context: ./server dockerfile: Dockerfile container_name: toir-server restart: unless-stopped depends_on: postgres: condition: service_healthy environment: PORT: 3000 DATABASE_URL: postgresql://${POSTGRES_USER:-postgres}:${POSTGRES_PASSWORD:-change-me}@postgres:5432/${POSTGRES_DB:-toir} CORS_ALLOWED_ORIGINS: ${CORS_ALLOWED_ORIGINS:-http://localhost:8080,https://toir.greact.ru} KEYCLOAK_ISSUER_URL: ${KEYCLOAK_ISSUER_URL:-https://sso.greact.ru/realms/toir} KEYCLOAK_AUDIENCE: ${KEYCLOAK_AUDIENCE:-toir-backend} KEYCLOAK_JWKS_URL: ${KEYCLOAK_JWKS_URL:-} healthcheck: test: ["CMD", "curl", "-fsS", "http://127.0.0.1:3000/health"] interval: 15s timeout: 5s retries: 5 start_period: 90s expose: - "3000" networks: - toir - proxy client: build: context: ./client dockerfile: Dockerfile args: VITE_API_URL: ${VITE_API_URL:-/api} VITE_KEYCLOAK_URL: ${VITE_KEYCLOAK_URL:-https://sso.greact.ru} VITE_KEYCLOAK_REALM: ${VITE_KEYCLOAK_REALM:-toir} VITE_KEYCLOAK_CLIENT_ID: ${VITE_KEYCLOAK_CLIENT_ID:-toir-frontend} container_name: toir-client restart: unless-stopped depends_on: server: condition: service_healthy healthcheck: test: ["CMD-SHELL", "wget -qO- http://127.0.0.1/healthz >/dev/null 2>&1 || exit 1"] interval: 15s timeout: 5s retries: 5 start_period: 10s ports: - "${CLIENT_PORT:-8080}:80" expose: - "80" networks: - toir - proxy volumes: postgres-data: networks: toir: driver: bridge proxy: external: true