2026-02-24 22:45:37 +05:30
|
|
|
# =============================================================================
|
|
|
|
|
# SurfSense — Development Docker Compose
|
|
|
|
|
# =============================================================================
|
|
|
|
|
# Usage (from repo root):
|
|
|
|
|
# docker compose -f docker/docker-compose.dev.yml up --build
|
|
|
|
|
#
|
|
|
|
|
# This file builds from source and includes dev tools like pgAdmin.
|
|
|
|
|
# For production with prebuilt images, use docker/docker-compose.yml instead.
|
|
|
|
|
# =============================================================================
|
|
|
|
|
|
|
|
|
|
name: surfsense
|
|
|
|
|
|
|
|
|
|
services:
|
|
|
|
|
db:
|
|
|
|
|
image: pgvector/pgvector:pg17
|
|
|
|
|
ports:
|
|
|
|
|
- "${POSTGRES_PORT:-5432}:5432"
|
|
|
|
|
volumes:
|
|
|
|
|
- postgres_data:/var/lib/postgresql/data
|
|
|
|
|
- ./postgresql.conf:/etc/postgresql/postgresql.conf:ro
|
|
|
|
|
- ./scripts/init-electric-user.sh:/docker-entrypoint-initdb.d/init-electric-user.sh:ro
|
|
|
|
|
environment:
|
2026-02-24 23:41:22 +05:30
|
|
|
- POSTGRES_USER=${DB_USER:-postgres}
|
|
|
|
|
- POSTGRES_PASSWORD=${DB_PASSWORD:-postgres}
|
|
|
|
|
- POSTGRES_DB=${DB_NAME:-surfsense}
|
2026-02-24 22:45:37 +05:30
|
|
|
- ELECTRIC_DB_USER=${ELECTRIC_DB_USER:-electric}
|
|
|
|
|
- ELECTRIC_DB_PASSWORD=${ELECTRIC_DB_PASSWORD:-electric_password}
|
|
|
|
|
command: postgres -c config_file=/etc/postgresql/postgresql.conf
|
|
|
|
|
healthcheck:
|
2026-02-24 23:41:22 +05:30
|
|
|
test: ["CMD-SHELL", "pg_isready -U ${DB_USER:-postgres} -d ${DB_NAME:-surfsense}"]
|
2026-02-24 22:45:37 +05:30
|
|
|
interval: 10s
|
|
|
|
|
timeout: 5s
|
|
|
|
|
retries: 5
|
|
|
|
|
|
|
|
|
|
pgadmin:
|
|
|
|
|
image: dpage/pgadmin4
|
|
|
|
|
ports:
|
|
|
|
|
- "${PGADMIN_PORT:-5050}:80"
|
|
|
|
|
environment:
|
|
|
|
|
- PGADMIN_DEFAULT_EMAIL=${PGADMIN_DEFAULT_EMAIL:-admin@surfsense.com}
|
|
|
|
|
- PGADMIN_DEFAULT_PASSWORD=${PGADMIN_DEFAULT_PASSWORD:-surfsense}
|
|
|
|
|
volumes:
|
|
|
|
|
- pgadmin_data:/var/lib/pgadmin
|
|
|
|
|
depends_on:
|
|
|
|
|
- db
|
|
|
|
|
|
|
|
|
|
redis:
|
|
|
|
|
image: redis:7-alpine
|
|
|
|
|
ports:
|
|
|
|
|
- "${REDIS_PORT:-6379}:6379"
|
|
|
|
|
volumes:
|
|
|
|
|
- redis_data:/data
|
|
|
|
|
command: redis-server --appendonly yes
|
|
|
|
|
healthcheck:
|
|
|
|
|
test: ["CMD", "redis-cli", "ping"]
|
|
|
|
|
interval: 10s
|
|
|
|
|
timeout: 5s
|
|
|
|
|
retries: 5
|
|
|
|
|
|
|
|
|
|
backend:
|
|
|
|
|
build: ../surfsense_backend
|
|
|
|
|
ports:
|
|
|
|
|
- "${BACKEND_PORT:-8000}:8000"
|
|
|
|
|
volumes:
|
|
|
|
|
- ../surfsense_backend/app:/app/app
|
|
|
|
|
- shared_temp:/shared_tmp
|
|
|
|
|
env_file:
|
|
|
|
|
- ../surfsense_backend/.env
|
|
|
|
|
environment:
|
2026-02-25 00:15:29 +05:30
|
|
|
- DATABASE_URL=${DATABASE_URL:-postgresql+asyncpg://${DB_USER:-postgres}:${DB_PASSWORD:-postgres}@${DB_HOST:-db}:${DB_PORT:-5432}/${DB_NAME:-surfsense}}
|
|
|
|
|
- CELERY_BROKER_URL=${REDIS_URL:-redis://redis:6379/0}
|
|
|
|
|
- CELERY_RESULT_BACKEND=${REDIS_URL:-redis://redis:6379/0}
|
|
|
|
|
- REDIS_APP_URL=${REDIS_URL:-redis://redis:6379/0}
|
2026-02-24 22:45:37 +05:30
|
|
|
- CELERY_TASK_DEFAULT_QUEUE=surfsense
|
|
|
|
|
- PYTHONPATH=/app
|
|
|
|
|
- UVICORN_LOOP=asyncio
|
|
|
|
|
- UNSTRUCTURED_HAS_PATCHED_LOOP=1
|
|
|
|
|
- LANGCHAIN_TRACING_V2=false
|
|
|
|
|
- LANGSMITH_TRACING=false
|
|
|
|
|
- ELECTRIC_DB_USER=${ELECTRIC_DB_USER:-electric}
|
|
|
|
|
- ELECTRIC_DB_PASSWORD=${ELECTRIC_DB_PASSWORD:-electric_password}
|
|
|
|
|
- AUTH_TYPE=${AUTH_TYPE:-LOCAL}
|
|
|
|
|
- NEXT_FRONTEND_URL=${NEXT_FRONTEND_URL:-http://localhost:3000}
|
2026-02-24 23:07:07 +05:30
|
|
|
- SERVICE_ROLE=api
|
2026-02-24 22:45:37 +05:30
|
|
|
depends_on:
|
|
|
|
|
db:
|
|
|
|
|
condition: service_healthy
|
|
|
|
|
redis:
|
|
|
|
|
condition: service_healthy
|
|
|
|
|
|
2026-02-24 23:07:07 +05:30
|
|
|
celery_worker:
|
|
|
|
|
build: ../surfsense_backend
|
|
|
|
|
volumes:
|
|
|
|
|
- ../surfsense_backend/app:/app/app
|
|
|
|
|
- shared_temp:/shared_tmp
|
|
|
|
|
env_file:
|
|
|
|
|
- ../surfsense_backend/.env
|
|
|
|
|
environment:
|
2026-02-25 00:15:29 +05:30
|
|
|
- DATABASE_URL=${DATABASE_URL:-postgresql+asyncpg://${DB_USER:-postgres}:${DB_PASSWORD:-postgres}@${DB_HOST:-db}:${DB_PORT:-5432}/${DB_NAME:-surfsense}}
|
|
|
|
|
- CELERY_BROKER_URL=${REDIS_URL:-redis://redis:6379/0}
|
|
|
|
|
- CELERY_RESULT_BACKEND=${REDIS_URL:-redis://redis:6379/0}
|
|
|
|
|
- REDIS_APP_URL=${REDIS_URL:-redis://redis:6379/0}
|
2026-02-24 23:07:07 +05:30
|
|
|
- CELERY_TASK_DEFAULT_QUEUE=surfsense
|
|
|
|
|
- PYTHONPATH=/app
|
|
|
|
|
- ELECTRIC_DB_USER=${ELECTRIC_DB_USER:-electric}
|
|
|
|
|
- ELECTRIC_DB_PASSWORD=${ELECTRIC_DB_PASSWORD:-electric_password}
|
|
|
|
|
- SERVICE_ROLE=worker
|
|
|
|
|
depends_on:
|
|
|
|
|
db:
|
|
|
|
|
condition: service_healthy
|
|
|
|
|
redis:
|
|
|
|
|
condition: service_healthy
|
|
|
|
|
backend:
|
|
|
|
|
condition: service_started
|
|
|
|
|
|
|
|
|
|
celery_beat:
|
|
|
|
|
build: ../surfsense_backend
|
|
|
|
|
env_file:
|
|
|
|
|
- ../surfsense_backend/.env
|
|
|
|
|
environment:
|
2026-02-25 00:15:29 +05:30
|
|
|
- DATABASE_URL=${DATABASE_URL:-postgresql+asyncpg://${DB_USER:-postgres}:${DB_PASSWORD:-postgres}@${DB_HOST:-db}:${DB_PORT:-5432}/${DB_NAME:-surfsense}}
|
|
|
|
|
- CELERY_BROKER_URL=${REDIS_URL:-redis://redis:6379/0}
|
|
|
|
|
- CELERY_RESULT_BACKEND=${REDIS_URL:-redis://redis:6379/0}
|
2026-02-24 23:07:07 +05:30
|
|
|
- CELERY_TASK_DEFAULT_QUEUE=surfsense
|
|
|
|
|
- PYTHONPATH=/app
|
|
|
|
|
- SERVICE_ROLE=beat
|
|
|
|
|
depends_on:
|
|
|
|
|
db:
|
|
|
|
|
condition: service_healthy
|
|
|
|
|
redis:
|
|
|
|
|
condition: service_healthy
|
|
|
|
|
celery_worker:
|
|
|
|
|
condition: service_started
|
|
|
|
|
|
|
|
|
|
# flower:
|
|
|
|
|
# build: ../surfsense_backend
|
|
|
|
|
# ports:
|
|
|
|
|
# - "${FLOWER_PORT:-5555}:5555"
|
|
|
|
|
# env_file:
|
|
|
|
|
# - ../surfsense_backend/.env
|
|
|
|
|
# environment:
|
2026-02-25 00:15:29 +05:30
|
|
|
# - CELERY_BROKER_URL=${REDIS_URL:-redis://redis:6379/0}
|
|
|
|
|
# - CELERY_RESULT_BACKEND=${REDIS_URL:-redis://redis:6379/0}
|
2026-02-24 23:07:07 +05:30
|
|
|
# - PYTHONPATH=/app
|
|
|
|
|
# command: celery -A app.celery_app flower --port=5555
|
|
|
|
|
# depends_on:
|
|
|
|
|
# - redis
|
|
|
|
|
# - celery_worker
|
|
|
|
|
|
2026-02-24 22:45:37 +05:30
|
|
|
electric:
|
2026-02-25 13:00:05 +05:30
|
|
|
image: electricsql/electric:1.4.6
|
2026-02-24 22:45:37 +05:30
|
|
|
ports:
|
|
|
|
|
- "${ELECTRIC_PORT:-5133}:3000"
|
|
|
|
|
# depends_on:
|
|
|
|
|
# - db
|
|
|
|
|
environment:
|
2026-02-25 00:15:29 +05:30
|
|
|
- DATABASE_URL=${ELECTRIC_DATABASE_URL:-postgresql://${ELECTRIC_DB_USER:-electric}:${ELECTRIC_DB_PASSWORD:-electric_password}@${DB_HOST:-db}:${DB_PORT:-5432}/${DB_NAME:-surfsense}?sslmode=${DB_SSLMODE:-disable}}
|
2026-02-24 22:45:37 +05:30
|
|
|
- ELECTRIC_INSECURE=true
|
|
|
|
|
- ELECTRIC_WRITE_TO_PG_MODE=direct
|
|
|
|
|
restart: unless-stopped
|
|
|
|
|
healthcheck:
|
|
|
|
|
test: ["CMD", "curl", "-f", "http://localhost:3000/v1/health"]
|
|
|
|
|
interval: 10s
|
|
|
|
|
timeout: 5s
|
|
|
|
|
retries: 5
|
|
|
|
|
|
|
|
|
|
frontend:
|
|
|
|
|
build:
|
|
|
|
|
context: ../surfsense_web
|
|
|
|
|
args:
|
|
|
|
|
NEXT_PUBLIC_FASTAPI_BACKEND_URL: ${NEXT_PUBLIC_FASTAPI_BACKEND_URL:-http://localhost:8000}
|
|
|
|
|
NEXT_PUBLIC_FASTAPI_BACKEND_AUTH_TYPE: ${NEXT_PUBLIC_FASTAPI_BACKEND_AUTH_TYPE:-LOCAL}
|
|
|
|
|
NEXT_PUBLIC_ETL_SERVICE: ${NEXT_PUBLIC_ETL_SERVICE:-DOCLING}
|
|
|
|
|
NEXT_PUBLIC_ELECTRIC_URL: ${NEXT_PUBLIC_ELECTRIC_URL:-http://localhost:5133}
|
|
|
|
|
NEXT_PUBLIC_ELECTRIC_AUTH_MODE: ${NEXT_PUBLIC_ELECTRIC_AUTH_MODE:-insecure}
|
|
|
|
|
NEXT_PUBLIC_DEPLOYMENT_MODE: ${NEXT_PUBLIC_DEPLOYMENT_MODE:-self-hosted}
|
|
|
|
|
ports:
|
|
|
|
|
- "${FRONTEND_PORT:-3000}:3000"
|
|
|
|
|
env_file:
|
|
|
|
|
- ../surfsense_web/.env
|
|
|
|
|
depends_on:
|
|
|
|
|
- backend
|
|
|
|
|
- electric
|
|
|
|
|
|
|
|
|
|
volumes:
|
|
|
|
|
postgres_data:
|
2026-02-26 10:23:38 +05:30
|
|
|
name: surfsense-postgres
|
2026-02-24 22:45:37 +05:30
|
|
|
pgadmin_data:
|
2026-02-26 10:23:38 +05:30
|
|
|
name: surfsense-pgadmin
|
2026-02-24 22:45:37 +05:30
|
|
|
redis_data:
|
2026-02-26 10:23:38 +05:30
|
|
|
name: surfsense-redis
|
2026-02-24 22:45:37 +05:30
|
|
|
shared_temp:
|
2026-02-26 10:23:38 +05:30
|
|
|
name: surfsense-shared-temp
|