-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcompose-dev.yml
More file actions
121 lines (116 loc) · 3.8 KB
/
compose-dev.yml
File metadata and controls
121 lines (116 loc) · 3.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
# For Docker: TTS/ASR/LLM on the *host* must use host.docker.internal (not 0.0.0.0).
# Copy .env.example to .env and set URLs. Defaults below point to host ports.
# UI at http://localhost:80 — proxies /v1 to backend
services:
talk:
image: dwani/talk-server:${DWANI_TALK_SERVER_TAG:-latest}
build: ./talk-server
expose:
- "8000"
depends_on:
agents:
condition: service_healthy
redis:
condition: service_healthy
postgres:
condition: service_healthy
healthcheck:
test: ["CMD", "python", "-c", "import urllib.request; urllib.request.urlopen('http://localhost:8000/health')"]
interval: 10s
timeout: 5s
retries: 3
start_period: 5s
environment:
DWANI_API_BASE_URL_TTS: ${DWANI_API_BASE_URL_TTS:-http://host.docker.internal:10804}
DWANI_API_BASE_URL_ASR: ${DWANI_API_BASE_URL_ASR:-http://host.docker.internal:10803}
DWANI_API_BASE_URL_LLM: ${DWANI_API_BASE_URL_LLM:-http://host.docker.internal:10802}
DWANI_LLM_MODEL: ${DWANI_LLM_MODEL:-gemma3}
DWANI_AGENT_BASE_URL: ${DWANI_AGENT_BASE_URL:-http://agents:8081}
DWANI_REDIS_URL: ${DWANI_REDIS_URL:-redis://redis:6379/0}
DWANI_DATABASE_URL: ${DWANI_DATABASE_URL:-postgresql+psycopg://talk:talk@postgres:5432/talk}
DWANI_API_KEY: ${DWANI_API_KEY:-}
DWANI_AUTH_COOKIE_NAME: ${DWANI_AUTH_COOKIE_NAME:-dwani_auth_session}
DWANI_AUTH_SESSION_TTL_SECONDS: ${DWANI_AUTH_SESSION_TTL_SECONDS:-86400}
DWANI_AUTH_COOKIE_SAMESITE: ${DWANI_AUTH_COOKIE_SAMESITE:-lax}
DWANI_AUTH_COOKIE_SECURE: ${DWANI_AUTH_COOKIE_SECURE:-0}
DWANI_LLM_API_KEY: ${DWANI_LLM_API_KEY:-dummy}
AGENTS_API_KEY: ${AGENTS_API_KEY:-}
extra_hosts:
- "host.docker.internal:host-gateway"
restart: unless-stopped
deploy:
resources:
limits:
cpus: "2.0"
memory: 2G
talk-ui:
image: dwani/talk-ux:${DWANI_TALK_UI_TAG:-latest}
build: ./talk-ui
ports:
- "80:80"
depends_on:
talk:
condition: service_healthy
restart: unless-stopped
deploy:
resources:
limits:
cpus: "1.0"
memory: 512M
agents:
image: dwani/talk-agents:${DWANI_TALK_AGENTS_TAG:-latest}
build: ./agents
expose:
- "8081"
healthcheck:
test: ["CMD", "python", "-c", "import urllib.request; urllib.request.urlopen('http://localhost:8081/healthz')"]
interval: 10s
timeout: 5s
retries: 3
start_period: 5s
environment:
LITELLM_MODEL_NAME: ${LITELLM_MODEL_NAME:-openai/gemma3}
LITELLM_API_BASE: ${LITELLM_API_BASE:-https://qwen/v1}
LITELLM_API_KEY: ${LITELLM_API_KEY}
AGENTS_API_KEY: ${AGENTS_API_KEY:-}
AGENTS_ALLOWED_ORIGINS: ${AGENTS_ALLOWED_ORIGINS:-http://localhost}
AGENTS_REDIS_URL: ${AGENTS_REDIS_URL:-redis://redis:6379/1}
volumes:
- fix_my_city_data:/app/fix-my-city/data
extra_hosts:
- "host.docker.internal:host-gateway"
restart: unless-stopped
deploy:
resources:
limits:
cpus: "2.0"
memory: 2G
redis:
image: redis:7-alpine
expose:
- "6379"
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 10s
timeout: 5s
retries: 3
restart: unless-stopped
postgres:
image: postgres:16-alpine
environment:
POSTGRES_USER: ${DWANI_POSTGRES_USER:-talk}
POSTGRES_PASSWORD: ${DWANI_POSTGRES_PASSWORD:-talk}
POSTGRES_DB: ${DWANI_POSTGRES_DB:-talk}
expose:
- "5432"
healthcheck:
test: ["CMD-SHELL", "pg_isready -U ${DWANI_POSTGRES_USER:-talk} -d ${DWANI_POSTGRES_DB:-talk}"]
interval: 10s
timeout: 5s
retries: 5
volumes:
- talk_postgres_data:/var/lib/postgresql/data
restart: unless-stopped
volumes:
fix_my_city_data:
talk_postgres_data: