-
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.override.yml
More file actions
124 lines (114 loc) · 3.14 KB
/
docker-compose.override.yml
File metadata and controls
124 lines (114 loc) · 3.14 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
services:
# Local adapters are available on their ports, but also available on:
# http://api.localhost.myapp.com: backend
# etc. To enable it, update .env, set:
# DOMAIN=localhost.myapp.com
proxy:
image: traefik:3.6.2
volumes:
- /var/run/docker.sock:/var/run/docker.sock
ports:
- "80:80"
- "8090:8080"
# Duplicate the command from docker-compose.yml to add --api.insecure=true
command:
# Enable Docker in Traefik, so that it reads labels from Docker adapters
- --providers.docker
# Add a constraint to only use adapters with the label for this stack
- --providers.docker.constraints=Label(`traefik.constraint-label`, `traefik-public`)
# Do not expose all Docker adapters, only the ones explicitly exposed
- --providers.docker.exposedbydefault=false
# Create an entrypoint "http" listening on port 80
- --entrypoints.http.address=:80
# Create an entrypoint "https" listening on port 443
- --entrypoints.https.address=:443
# Enable the access log, with HTTP requests
- --accesslog
# Enable the Traefik log, for configurations and errors
- --log
# Enable debug logging for local development
- --log.level=DEBUG
# Enable the Dashboard and API
- --api
# Enable the Dashboard and API in insecure mode for local development
- --api.insecure=true
labels:
# Enable Traefik for this service, to make it available in the public network
- traefik.enable=true
- traefik.constraint-label=traefik-public
# Dummy https-redirect middleware that doesn't really redirect, only to
# allow running it locally
- traefik.http.middlewares.https-redirect.contenttype.autodetect=false
networks:
- traefik-public
- default
db:
restart: "no"
ports:
- "5432:5432"
adminer:
restart: "no"
ports:
- "5080:5080"
api:
restart: "no"
ports:
- "8000:8000"
build:
target: dev
develop:
watch:
- path: .
action: sync
target: /app
ignore:
- .venv
- path: ./pyproject.toml
action: rebuild
environment:
SMTP_HOST: "mailcatcher"
SMTP_PORT: "1025"
SMTP_TLS: "false"
EMAILS_FROM_EMAIL: "noreply@example.com"
# Enables autoreload.
APP_RELOAD: "True"
maildev:
image: maildev/maildev
environment:
- TZ=Asia/Vladivostok
- MAILDEV_WEB_PORT=1080
- MAILDEV_SMTP_PORT=1025
ports:
- "8888:1080"
- "1025:1025"
logging:
driver: "json-file"
options:
max-size: "1m"
taskiq-worker:
restart: "no"
ports:
- "8081:8000"
volumes:
# Adds current directory as volume.
- .:/app/src/
redis:
restart: "no"
ports:
- "6379:6379"
rmq:
image: rabbitmq:4.2.0-management-alpine
restart: "no"
ports:
- "5672:5672"
- "15672:15672"
kafka:
restart: "no"
ports:
- "9092:9092"
- "9093:9093"
- "9094:9094"
networks:
traefik-public:
# For local dev, don't expect an external Traefik network
external: false