-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathdocker-compose.dev.yaml
89 lines (81 loc) · 1.79 KB
/
docker-compose.dev.yaml
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
version: '3.8'
services:
# Redis
redis:
image: redis
container_name: redis
restart: unless-stopped
command: redis-server --requirepass password
volumes:
- redis-data:/data
ports:
- 6379:6379
networks:
- mlnet
# Rabbitmq
rabbitmq:
image: rabbitmq:3-management-alpine
container_name: 'rabbitmq'
ports:
- 5672:5672
- 15672:15672
environment:
- RABBITMQ_DEFAULT_USER=guest
- RABBITMQ_DEFAULT_PASS=guest
volumes:
- rabbitmq-data:/var/lib/rabbitmq/
- rabbitmq-logs:/var/log/rabbitmq
networks:
- mlnet
# API
ml-api:
build:
context: ./ml-api
dockerfile: ./Dockerfile
container_name: ml-api
restart: unless-stopped
command: sh -c "uvicorn main:app --host 0.0.0.0 --port 8081 --reload"
volumes:
- ./ml-api/app:/app/
- ./ml-storages:/storages/
- ./api-logs:/logs/
ports:
- 8081:8081
networks:
- mlnet
# Celery object detection
ml-celery:
build:
context: ./ml-celery
dockerfile: ./Dockerfile
container_name: ml-celery
restart: unless-stopped
command: sh -c "celery -A tasks worker --loglevel=info --concurrency=1 -E --logfile=/logs/celery.log"
volumes:
- ./ml-celery/app:/app/
- ./ml-storages:/storages/
- ./celery-logs:/logs/
networks:
- mlnet
# Client
ml-client:
build:
context: ./ml-client
dockerfile: ./Dockerfile
environment:
DOMAIN: localhost
BE_HOST: ml-api
BE_PORT: 8081
container_name: ml-client
restart: unless-stopped
ports:
- 80:80
command: sh -c "./custom_nginx.sh && nginx -g 'daemon off;'"
networks:
- mlnet
networks:
mlnet:
volumes:
redis-data:
rabbitmq-data:
rabbitmq-logs: