-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathdocker-compose.worker.yml
More file actions
80 lines (76 loc) · 2.53 KB
/
docker-compose.worker.yml
File metadata and controls
80 lines (76 loc) · 2.53 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
services:
db:
image: postgres:15-alpine
container_name: lyra-worker-db
environment:
POSTGRES_USER: ${POSTGRES_USER?POSTGRES_USER is required}
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD?POSTGRES_PASSWORD is required}
POSTGRES_DB: ${POSTGRES_DB?POSTGRES_DB is required}
volumes:
- worker_postgres_data:/var/lib/postgresql/data
ports:
- "5432:5432"
healthcheck:
test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER?POSTGRES_USER is required}"]
interval: 5s
timeout: 5s
retries: 5
restart: always
redis:
image: redis:alpine
container_name: lyra-worker-redis
ports:
- "6379:6379"
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 5s
timeout: 5s
retries: 5
restart: always
backend:
build: ./backend
container_name: lyra-worker-backend
command: sh -c "alembic upgrade head && uvicorn app.main:app --host 0.0.0.0 --port 8000"
volumes:
- ./backend:/app
- /var/run/docker.sock:/var/run/docker.sock
- worker_runtime_data:/var/lib/lyra/worker
ports:
- "8000:8000"
environment:
- DATABASE_URL=${DATABASE_URL?DATABASE_URL is required}
- CELERY_BROKER_URL=${CELERY_BROKER_URL?CELERY_BROKER_URL is required}
- CELERY_RESULT_BACKEND=${CELERY_RESULT_BACKEND?CELERY_RESULT_BACKEND is required}
- APP_SECRET_KEY=${APP_SECRET_KEY?APP_SECRET_KEY is required}
- ALLOW_ORIGINS=${ALLOW_ORIGINS?ALLOW_ORIGINS is required}
- LYRA_NODE_ROLE=worker
- SSH_HOST_KEY_POLICY=${SSH_HOST_KEY_POLICY?SSH_HOST_KEY_POLICY is required}
- SSH_KNOWN_HOSTS_PATH=${SSH_KNOWN_HOSTS_PATH?SSH_KNOWN_HOSTS_PATH is required}
depends_on:
db:
condition: service_healthy
redis:
condition: service_healthy
restart: always
worker:
build: ./backend
container_name: lyra-worker-celery
command: celery -A app.worker worker --loglevel=info
volumes:
- ./backend:/app
- /var/run/docker.sock:/var/run/docker.sock
environment:
- DATABASE_URL=${DATABASE_URL?DATABASE_URL is required}
- CELERY_BROKER_URL=${CELERY_BROKER_URL?CELERY_BROKER_URL is required}
- CELERY_RESULT_BACKEND=${CELERY_RESULT_BACKEND?CELERY_RESULT_BACKEND is required}
- APP_SECRET_KEY=${APP_SECRET_KEY?APP_SECRET_KEY is required}
- LYRA_NODE_ROLE=worker
depends_on:
db:
condition: service_healthy
redis:
condition: service_healthy
restart: always
volumes:
worker_postgres_data:
worker_runtime_data: