services: postgres: image: postgres:16-alpine environment: POSTGRES_USER: ${POSTGRES_USER} POSTGRES_PASSWORD: ${POSTGRES_PASSWORD} POSTGRES_DB: ${POSTGRES_DB} volumes: - postgres_data:/var/lib/postgresql/data healthcheck: test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER}"] interval: 5s timeout: 5s retries: 5 backend: build: ./backend environment: DATABASE_URL: ${DATABASE_URL} SECRET_KEY: ${SECRET_KEY} BACKEND_CORS_ORIGINS: ${BACKEND_CORS_ORIGINS} ENVIRONMENT: ${ENVIRONMENT} ACCESS_TOKEN_EXPIRE_MINUTES: ${ACCESS_TOKEN_EXPIRE_MINUTES} REFRESH_TOKEN_EXPIRE_DAYS: ${REFRESH_TOKEN_EXPIRE_DAYS} REFRESH_TOKEN_EXPIRE_HOURS: ${REFRESH_TOKEN_EXPIRE_HOURS} FIRST_ADMIN_EMAIL: ${FIRST_ADMIN_EMAIL} FIRST_ADMIN_USERNAME: ${FIRST_ADMIN_USERNAME} FIRST_ADMIN_PASSWORD: ${FIRST_ADMIN_PASSWORD} depends_on: postgres: condition: service_healthy frontend: build: ./frontend depends_on: - backend nginx: build: ./nginx ports: - "80:80" depends_on: - backend - frontend volumes: postgres_data: