-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
131 lines (126 loc) · 3.44 KB
/
docker-compose.yml
File metadata and controls
131 lines (126 loc) · 3.44 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
122
123
124
125
126
127
128
129
130
131
services:
# MongoDB Database
mongodb:
image: mongo:7
container_name: intervai-mongodb
restart: unless-stopped
ports:
- "27017:27017"
environment:
MONGO_INITDB_ROOT_USERNAME: ${MONGO_ROOT_USER:-admin}
MONGO_INITDB_ROOT_PASSWORD: ${MONGO_ROOT_PASSWORD:-password123}
MONGO_INITDB_DATABASE: ${MONGO_DB_NAME:-intervai_db}
volumes:
- mongodb_data:/data/db
- mongodb_config:/data/configdb
- ./mongo-init.js:/docker-entrypoint-initdb.d/mongo-init.js:ro
networks:
- intervai-network
healthcheck:
test: ["CMD", "mongosh", "--eval", "db.adminCommand('ping')"]
interval: 10s
timeout: 5s
retries: 5
start_period: 20s
# Redis Cache & Queue Backend
redis:
image: redis:7-alpine
container_name: intervai-redis
restart: unless-stopped
ports:
- "6379:6379"
volumes:
- redis_data:/data
networks:
- intervai-network
command: redis-server --appendonly yes --maxmemory 512mb --maxmemory-policy allkeys-lru --requirepass ${REDIS_PASSWORD:-redis123}
healthcheck:
test: ["CMD", "redis-cli", "--raw", "incr", "ping"]
interval: 10s
timeout: 3s
retries: 5
start_period: 10s
# Main API Server
api:
build:
context: .
dockerfile: Dockerfile
container_name: intervai-api
restart: unless-stopped
env_file:
- .env
ports:
- "${PORT:-8000}:${PORT:-8000}"
environment:
NODE_ENV: ${NODE_ENV:-production}
PORT: ${PORT:-8000}
MONGO_URI: mongodb://${MONGO_ROOT_USER:-admin}:${MONGO_ROOT_PASSWORD:-password123}@mongodb:27017/${MONGO_DB_NAME:-intervai_db}?authSource=admin
JWT_SECRET: ${JWT_SECRET}
GROQ_API: ${GROQ_API_KEY}
GROQ_API_KEY: ${GROQ_API_KEY}
REDIS_HOST: redis
REDIS_PORT: 6379
REDIS_PASSWORD: ${REDIS_PASSWORD:-redis123}
CLIENT_URL: ${CLIENT_URL:-http://localhost:3000}
depends_on:
mongodb:
condition: service_healthy
redis:
condition: service_healthy
networks:
- intervai-network
volumes:
- ./exports:/app/exports
- ./logs:/app/logs
healthcheck:
test: ["CMD", "wget", "--spider", "-q", "http://localhost:${PORT:-8000}/health"]
interval: 30s
timeout: 10s
retries: 3
start_period: 40s
# Background Worker for AI & Exports
worker:
build:
context: .
dockerfile: Dockerfile.worker
container_name: intervai-worker
restart: unless-stopped
env_file:
- .env
environment:
NODE_ENV: ${NODE_ENV:-production}
MONGO_URI: mongodb://${MONGO_ROOT_USER:-admin}:${MONGO_ROOT_PASSWORD:-password123}@mongodb:27017/${MONGO_DB_NAME:-intervai_db}?authSource=admin
GROQ_API: ${GROQ_API_KEY}
GROQ_API_KEY: ${GROQ_API_KEY}
REDIS_HOST: redis
REDIS_PORT: 6379
REDIS_PASSWORD: ${REDIS_PASSWORD:-redis123}
depends_on:
mongodb:
condition: service_healthy
redis:
condition: service_healthy
networks:
- intervai-network
volumes:
- ./exports:/app/exports
- ./logs:/app/logs
healthcheck:
test: ["CMD", "node", "-e", "process.exit(0)"]
interval: 30s
timeout: 10s
retries: 3
start_period: 20s
networks:
intervai-network:
driver: bridge
ipam:
config:
- subnet: 172.20.0.0/16
volumes:
mongodb_data:
driver: local
mongodb_config:
driver: local
redis_data:
driver: local