Files
microdao-daarion/docker-compose.node2-sofiia.yml
Apple 89c3f2ac66 P1: NCS-first model selection + NATS capabilities + Grok 4.1
Router model selection:
- New model_select.py: resolve_effective_profile → profile_requirements →
  select_best_model pipeline. NCS-first with graceful static fallback.
- selection_policies in router-config.node2.yml define prefer order per
  profile without hardcoding models (e.g. local_default_coder prefers
  qwen3:14b then qwen3.5:35b-a3b).
- Cloud profiles (cloud_grok, cloud_deepseek) skip NCS; on cloud failure
  use fallback_profile via NCS for local selection.
- Structured logs: selected_profile, required_type, runtime, model,
  caps_age_s, fallback_reason on every infer request.

Grok model fix:
- grok-2-1212 no longer exists on xAI API → updated to
  grok-4-1-fast-reasoning across all 3 hardcoded locations in main.py
  and router-config.node2.yml.

NCS NATS request/reply:
- node-capabilities subscribes to node.noda2.capabilities.get (NATS
  request/reply). Enabled via ENABLE_NATS_CAPS=true in compose.
- NODA1 router can query NODA2 capabilities over NATS leafnode without
  HTTP connectivity.

Verified:
- NCS: 14 served models from Ollama+Swapper+llama-server
- NATS: request/reply returns full capabilities JSON
- Sofiia: cloud_grok → grok-4-1-fast-reasoning (tested, 200 OK)
- Helion: NCS → qwen3:14b via Ollama (caps_age=23.7s cache hit)
- Router health: ok

Made-with: Cursor
2026-02-27 02:17:34 -08:00

177 lines
5.5 KiB
YAML

version: "3.8"
services:
router:
build:
context: ./services/router
dockerfile: Dockerfile
container_name: dagi-router-node2
ports:
- "127.0.0.1:9102:8000"
environment:
- NODE_ID=NODA2
- DAGI_ROUTER_CONFIG=/app/router-config.yml
- MEMORY_SERVICE_URL=http://memory-service:8000
- NATS_URL=nats://dagi-nats:4222
- QDRANT_HOST=qdrant-node2
- QDRANT_PORT=6333
- DATABASE_URL=postgresql://daarion:daarion_secret_node2@postgres-node2:5432/daarion_memory
- NEO4J_BOLT_URL=bolt://neo4j-node2:7687
- NEO4J_USER=neo4j
- NEO4J_PASSWORD=daarion_node2_secret
- CITY_SERVICE_URL=http://city-service:7001
- PIECES_OS_URL=http://host.docker.internal:39300
- NOTION_API_KEY=${NOTION_API_KEY:-}
- XAI_API_KEY=${XAI_API_KEY}
- GROK_API_KEY=${XAI_API_KEY}
- DEEPSEEK_API_KEY=${DEEPSEEK_API_KEY:-}
# ── Node Capabilities ─────────────────────────────────────────────────
- NODE_CAPABILITIES_URL=http://node-capabilities:8099/capabilities
# ── Persistence backends ──────────────────────────────────────────────
- ALERT_BACKEND=postgres
- ALERT_DATABASE_URL=${ALERT_DATABASE_URL:-${DATABASE_URL}}
- RISK_HISTORY_BACKEND=auto
- BACKLOG_BACKEND=auto
- INCIDENT_BACKEND=auto
- AUDIT_BACKEND=auto
volumes:
- ./services/router/router-config.node2.yml:/app/router-config.yml:ro
- ./logs:/app/logs
extra_hosts:
- "host.docker.internal:host-gateway"
- "city-service:host-gateway"
- "daarion-city-service:host-gateway"
depends_on:
- dagi-nats
- node-capabilities
networks:
- dagi-network
- dagi-memory-network
restart: unless-stopped
gateway:
build:
context: ./gateway-bot
dockerfile: Dockerfile
container_name: dagi-gateway-node2
ports:
- "0.0.0.0:9300:9300"
environment:
- ROUTER_URL=http://router:8000
- DAARWIZZ_NAME=DAARWIZZ
- DAARWIZZ_PROMPT_PATH=/app/gateway-bot/daarwizz_prompt.txt
- MEMORY_SERVICE_URL=http://memory-service:8000
- SOFIIA_NAME=SOFIIA
- SOFIIA_PROMPT_PATH=/app/gateway-bot/sofiia_prompt.txt
- SOFIIA_TELEGRAM_BOT_TOKEN=${SOFIIA_TELEGRAM_BOT_TOKEN}
volumes:
- ./gateway-bot:/app/gateway-bot:ro
- ./logs:/app/logs
depends_on:
- router
networks:
- dagi-network
- dagi-memory-network
restart: unless-stopped
dagi-nats:
image: nats:2.10-alpine
container_name: dagi-nats-node2
ports:
- "4222:4222"
- "8222:8222"
command: -c /etc/nats/nats-server.conf
volumes:
- ./nats-server.conf:/etc/nats/nats-server.conf:ro
networks:
- dagi-network
restart: unless-stopped
swapper-service:
build:
context: ./services/swapper-service
dockerfile: Dockerfile
container_name: swapper-service-node2
ports:
- "127.0.0.1:8890:8890"
extra_hosts:
- "host.docker.internal:host-gateway"
environment:
- OLLAMA_BASE_URL=http://host.docker.internal:11434
- SWAPPER_CONFIG_PATH=/app/config/swapper_config_node2.yaml
- SWAPPER_MODE=single-active
- MODEL_SWAP_TIMEOUT=300
volumes:
- ./services/swapper-service/config:/app/config:ro
- ./logs:/app/logs
networks:
- dagi-network
restart: unless-stopped
node-capabilities:
build:
context: ./services/node-capabilities
dockerfile: Dockerfile
container_name: node-capabilities-node2
ports:
- "127.0.0.1:8099:8099"
extra_hosts:
- "host.docker.internal:host-gateway"
environment:
- NODE_ID=NODA2
- OLLAMA_BASE_URL=http://host.docker.internal:11434
- SWAPPER_URL=http://swapper-service:8890
- LLAMA_SERVER_URL=http://host.docker.internal:11435
- CACHE_TTL_SEC=15
- ENABLE_NATS_CAPS=true
- NATS_URL=nats://dagi-nats:4222
depends_on:
- swapper-service
- dagi-nats
networks:
- dagi-network
restart: unless-stopped
sofiia-console:
build:
context: ./services/sofiia-console
dockerfile: Dockerfile
container_name: sofiia-console
ports:
- "127.0.0.1:8002:8002"
environment:
- PORT=8002
- ENV=${ENV:-prod}
- NODE_ID=NODA2
- ROUTER_URL=http://router:8000
- CONFIG_DIR=/app/config
- NODES_NODA2_ROUTER_URL=http://router:8000
- NODES_NODA1_ROUTER_URL=http://144.76.224.179:9102
- MEMORY_SERVICE_URL=http://memory-service:8000
- OLLAMA_URL=${OLLAMA_URL:-http://host.docker.internal:11434}
- NOTION_API_KEY=${NOTION_API_KEY:-}
- OPENCODE_URL=${OPENCODE_URL:-}
# P1 SECURITY: SSH_PASSWORD removed — use key file instead
# NODES_NODA1_SSH_PASSWORD is NO LONGER passed; sofiia-console reads from key file
- NODES_NODA1_SSH_PRIVATE_KEY=/run/secrets/noda1_ssh_key
- SUPERVISOR_API_KEY=${SUPERVISOR_API_KEY}
- SOFIIA_CONSOLE_API_KEY=${SOFIIA_CONSOLE_API_KEY}
- CORS_ORIGINS=${CORS_ORIGINS:-}
volumes:
- ./config:/app/config
- ./secrets/noda1_id_ed25519:/run/secrets/noda1_ssh_key:ro
depends_on:
- router
networks:
- dagi-network
- dagi-memory-network
restart: unless-stopped
networks:
dagi-network:
driver: bridge
name: dagi-network-node2
dagi-memory-network:
external: true
name: dagi-memory-network-node2