services: postgres: image: postgis/postgis:16-3.4-alpine restart: unless-stopped ports: - "127.0.0.1:5432:5432" environment: POSTGRES_USER: ${DB_USER:-relink} POSTGRES_PASSWORD: ${DB_PASSWORD:?DB_PASSWORD is required} POSTGRES_DB: ${DB_NAME:-relink_prod} volumes: - postgres_data:/var/lib/postgresql/data healthcheck: test: ["CMD-SHELL", "pg_isready -U ${DB_USER:-relink} -d ${DB_NAME:-relink_prod}"] interval: 10s timeout: 5s retries: 5 redis: image: redis:7-alpine restart: unless-stopped ports: - "127.0.0.1:6379:6379" command: redis-server --requirepass ${REDIS_PASSWORD:?REDIS_PASSWORD is required} volumes: - redis_data:/data healthcheck: test: ["CMD", "redis-cli", "-a", "${REDIS_PASSWORD}", "ping"] interval: 10s timeout: 5s retries: 5 web: build: context: . dockerfile: Dockerfile args: APP_NAME: web restart: unless-stopped ports: - "127.0.0.1:3000:3000" environment: DATABASE_URL: postgresql://${DB_USER:-relink}:${DB_PASSWORD}@postgres:5432/${DB_NAME:-relink_prod}?schema=public REDIS_URL: redis://:${REDIS_PASSWORD}@redis:6379 NEXTAUTH_URL: ${NEXTAUTH_URL:-http://localhost:3000} NEXTAUTH_SECRET: ${NEXTAUTH_SECRET:?NEXTAUTH_SECRET is required} NODE_ENV: production depends_on: postgres: condition: service_healthy redis: condition: service_healthy admin: build: context: . dockerfile: Dockerfile args: APP_NAME: admin restart: unless-stopped ports: - "127.0.0.1:3001:3000" environment: DATABASE_URL: postgresql://${DB_USER:-relink}:${DB_PASSWORD}@postgres:5432/${DB_NAME:-relink_prod}?schema=public REDIS_URL: redis://:${REDIS_PASSWORD}@redis:6379 NODE_ENV: production depends_on: postgres: condition: service_healthy redis: condition: service_healthy nginx: image: nginx:alpine restart: unless-stopped ports: - "80:80" - "443:443" volumes: - ./deploy/nginx/default.conf:/etc/nginx/conf.d/default.conf:ro - ./deploy/nginx/ssl:/etc/nginx/ssl:ro depends_on: - web - admin volumes: postgres_data: redis_data: