Files
Vector/docker-compose.yml
T
josh 439c1b41e6
CI / Lint · Typecheck · Test · Build (push) Successful in 51s
CI / Playwright (smoke) (push) Has been skipped
CI / Build & push images (push) Successful in 5m47s
deploy(compose): inline restart: unless-stopped per service
Drop the x-restart YAML anchor — three-char-longer per service isn't
worth the indirection.
2026-04-16 21:31:30 -04:00

65 lines
1.7 KiB
YAML

# Vector — single-instance production deployment.
#
# Quick start:
# 1. Log in to the registry so compose can pull:
# docker login gitea.thewrightserver.net
#
# 2. Create a .env file next to this compose file containing at minimum:
# JWT_SECRET=<64+ char random hex>
# CLIENT_ORIGIN=http://your-host:8080
# WEB_PORT=8080
# TAG=latest # or a specific commit SHA
#
# 3. Pull + start:
# docker compose pull && docker compose up -d
#
# Data lives in the `vector-data` volume (SQLite db). Redis is included
# in anticipation of the BullMQ worker follow-up; the API does not yet
# depend on it.
services:
api:
image: gitea.thewrightserver.net/josh/vector-api:${TAG:-latest}
restart: unless-stopped
environment:
NODE_ENV: production
PORT: 3001
DATABASE_URL: file:/data/vector.db
JWT_SECRET: ${JWT_SECRET:?JWT_SECRET is required — see .env.example}
CLIENT_ORIGIN: ${CLIENT_ORIGIN:-http://localhost:8080}
volumes:
- vector-data:/data
healthcheck:
test: ["CMD-SHELL", "wget -qO- http://localhost:3001/healthz || exit 1"]
interval: 30s
timeout: 5s
retries: 3
start_period: 20s
depends_on:
redis:
condition: service_healthy
web:
image: gitea.thewrightserver.net/josh/vector-web:${TAG:-latest}
restart: unless-stopped
ports:
- "${WEB_PORT:-8080}:80"
depends_on:
api:
condition: service_healthy
redis:
image: redis:7-alpine
restart: unless-stopped
volumes:
- vector-redisdata:/data
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 5s
timeout: 3s
retries: 10
volumes:
vector-data:
vector-redisdata: