# Production Docker Compose # Usage: docker-compose -f docker-compose.prod.yml up -d services: postgres: image: postgres:18-alpine container_name: galaxis-po-db environment: POSTGRES_USER: ${DB_USER} POSTGRES_PASSWORD: ${DB_PASSWORD} POSTGRES_DB: ${DB_NAME} volumes: - postgres_data:/var/lib/postgresql/data healthcheck: test: ["CMD-SHELL", "pg_isready -U ${DB_USER} -d ${DB_NAME}"] interval: 5s timeout: 5s retries: 5 restart: always networks: - galaxy-net backend: build: context: ./backend dockerfile: Dockerfile container_name: galaxis-po-backend env_file: - .env.prod environment: DATABASE_URL: postgresql://${DB_USER}:${DB_PASSWORD}@postgres:5432/${DB_NAME} PYTHONPATH: /app depends_on: postgres: condition: service_healthy restart: always networks: - galaxy-net frontend: build: context: ./frontend dockerfile: Dockerfile target: production container_name: galaxis-po-frontend environment: NEXT_PUBLIC_API_URL: ${API_URL} depends_on: backend: condition: service_healthy restart: always networks: - galaxy-net nginx: image: nginx:alpine container_name: galaxis-po-nginx ports: - "80:80" - "443:443" volumes: - ./nginx.conf:/etc/nginx/nginx.conf:ro - ./certs:/etc/nginx/certs:ro depends_on: - frontend - backend restart: always networks: - galaxy-net volumes: postgres_data: driver: local networks: galaxy-net: driver: bridge