-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocker-compose.master.yml
64 lines (62 loc) · 1.92 KB
/
docker-compose.master.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
version: "3.3"
services:
master:
image: "ghcr.io/osom8979/osom-api:latest"
build: .
restart: always
logging:
driver: "json-file"
options:
max-size: "10m"
max-file: "10"
env_file:
- .env.local
user: ${USER_UID:?err}:${USER_GID:?err}
command: master
deploy:
mode: replicated
replicas: 2
labels:
- "traefik.enable=true"
- "traefik.docker.network=osom-net"
- "traefik.http.routers.osom_master.rule=Host(`${FRONTEND_HOST:?err}`)"
- "traefik.http.routers.osom_master.entrypoints=websecure"
- "traefik.http.routers.osom_master.tls.certresolver=osom_resolver"
- "traefik.http.services.osom_master.loadbalancer.server.port=10503"
depends_on:
- traefik
traefik:
image: "traefik:v2.10"
restart: always
logging:
driver: "json-file"
options:
max-size: "10m"
max-file: "10"
env_file:
- .env.local
ports:
- "443:443"
- "8080:8080"
volumes:
- "/var/run/docker.sock:/var/run/docker.sock:ro"
- "./letsencrypt:/letsencrypt"
healthcheck:
test: ["CMD", "traefik", "healthcheck", "--ping"]
interval: 10s
timeout: 8s
retries: 5
command:
- "--ping=true"
- "--api.insecure=true"
- "--providers.docker=true"
- "--providers.docker.exposedbydefault=false"
#- "--entrypoints.web.address=:80"
#- "--entrypoints.web.http.redirections.entrypoint.to=websecure"
#- "--entrypoints.web.http.redirections.entrypoint.scheme=https"
#- "--entrypoints.web.http.redirections.entrypoint.permanent=true"
- "--entrypoints.websecure.address=:443"
- "--certificatesresolvers.osom_resolver.acme.tlschallenge=true"
- "--certificatesresolvers.osom_resolver.acme.email=${ACME_EMAIL:?err}"
- "--certificatesresolvers.osom_resolver.acme.storage=/letsencrypt/acme.json"
#- "--log.level=DEBUG"