services: timescale_db: image: timescale/timescaledb-ha:pg16-ts2.15-oss restart: always # No ports needed if only internal, but keep for CLI access if desired ports: - "5599:5432" environment: - POSTGRES_DB=${POSTGRES_DB} - POSTGRES_USER=${POSTGRES_USER} - POSTGRES_PASSWORD=${POSTGRES_PASSWORD} volumes: - timescale-data:/var/lib/postgresql/data healthcheck: test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER} -d ${POSTGRES_DB}"] interval: 10s timeout: 5s retries: 5 ingest_movement: build: context: . dockerfile: Dockerfile restart: always depends_on: timescale_db: condition: service_healthy env_file: .env # Coolify will inject variables here ingest_events: build: context: . dockerfile: Dockerfile restart: always depends_on: timescale_db: condition: service_healthy grafana: image: grafana/grafana:11.0.0 restart: always depends_on: timescale_db: condition: service_healthy environment: - GF_SECURITY_ADMIN_PASSWORD=${GRAFANA_ADMIN_PASSWORD} volumes: - grafana-data:/var/lib/grafana # COOLIFY DOMAIN LOGIC: # You will set the actual URL in the Coolify UI, # but the service needs to expose port 3000 internally. volumes: timescale-data: name: timescale-data grafana-data: name: grafana-data