-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocker-compose.yml
70 lines (68 loc) · 2.09 KB
/
docker-compose.yml
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
version: '3.8'
services:
db:
image: mariadb:10.6
restart: always
environment:
- MARIADB_DATABASE=panu
- MARIADB_PASSWORD=${MARIADB_PASSWORD}
- MARIADB_USER=panu
- MARIADB_RANDOM_ROOT_PASSWORD=1
volumes:
- ./db/data:/var/lib/mysql
networks:
- back-tier
ports:
- 3306:3306
healthcheck:
test: ["CMD", "mysqladmin", "ping", "-h", "localhost"]
interval: 30s
timeout: 10s
retries: 5
panu:
build:
context: .
args:
EXTERNAL_URL: ${EXTERNAL_URL}
depends_on:
- db
restart: always
networks:
- back-tier
command: sh -c './wait-for db:3306 -- python3 panu.py'
shortener:
image: php:8.0-apache
build: shortener/
networks:
- front-tier
- back-tier
ports:
- 80:80
labels:
- "traefik.enable=true"
- "traefik.http.routers.shortener.rule=Host(`${LETSENCRYPT_DOMAIN}`)"
- "traefik.http.routers.shortener.entrypoints=websecure"
- "traefik.http.routers.shortener.tls.certresolver=myresolver"
traefik:
image: traefik:v2.5
volumes:
# So that Traefik can listen to the Docker events
- "/var/run/docker.sock:/var/run/docker.sock:ro"
- "./letsencrypt:/letsencrypt"
ports:
- "443:443"
- "8080:8080"
networks:
- front-tier
- back-tier
command:
- "--api.insecure=false"
- "--providers.docker=true"
- "--providers.docker.exposedbydefault=false"
- "--entrypoints.websecure.address=:443"
- "--certificatesresolvers.myresolver.acme.tlschallenge=true"
- "--certificatesresolvers.myresolver.acme.email=${LETSENCRYPT_EMAIL}"
- "--certificatesresolvers.myresolver.acme.storage=/letsencrypt/acme.json"
networks:
back-tier:
front-tier: