blob: 98332cc27d06194c547bf6ae3450da85031d5387 (
plain)
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
|
services:
mon:
image: twinproduction/gatus:latest
volumes:
- "{{ mon_base }}/volumes/gatus/data:/data"
- "{{ mon_base }}/volumes/gatus/config:/config"
environment:
- TZ={{ timezone }}
- DEPLOYMENT_TIME={{ deployment_time }}
networks:
- proxy
- metrics
deploy:
mode: replicated
update_config:
parallelism: 1
failure_action: rollback
order: start-first
delay: 5s
monitor: 30s
replicas: 1
labels:
- traefik.enable=true
- traefik.swarm.network=proxy
- traefik.http.routers.mon.middlewares=oauth-verify
- traefik.http.routers.mon.tls=true
- traefik.http.routers.mon.tls.certResolver=letsencrypt
- traefik.http.routers.mon.rule=Host(`{{ mon_domain }}`)
- traefik.http.routers.mon.entrypoints=websecure
- traefik.http.services.mon.loadbalancer.server.port=8080
prometheus:
image: prom/prometheus:latest
volumes:
- "{{ mon_base }}/volumes/prometheus/config.yml:/etc/prometheus/prometheus.yml"
networks:
- proxy
- metrics
environment:
- TZ={{ timezone }}
- DEPLOYMENT_TIME={{ deployment_time }}
deploy:
mode: replicated
replicas: 1
update_config:
parallelism: 1
order: start-first
failure_action: rollback
labels:
- traefik.enable=true
- traefik.swarm.network=proxy
- traefik.http.routers.prometheus.tls=true
- traefik.http.routers.prometheus.tls.certResolver=letsencrypt
- traefik.http.routers.prometheus.rule=Host(`{{ prometheus_domain }}`)
- traefik.http.routers.prometheus.entrypoints=websecure
- traefik.http.services.prometheus.loadbalancer.server.port=9090
networks:
proxy:
external: true
metrics:
name: metrics
driver: overlay
attachable: true
|