-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocker-compose.yml
125 lines (117 loc) · 2.98 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
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
125
volumes:
prometheus_data: {}
grafana_data: {}
networks:
front-tier: null
back-tier: null
services:
alertmanager:
image: docker.io/prom/alertmanager:v0.27.0
ports:
- 9093:9093
volumes:
- ./alertmanager/:/etc/alertmanager/
networks:
- back-tier
command:
- --config.file=/etc/alertmanager/config.yml
- --storage.path=/alertmanager
blackbox_exporter:
image: docker.io/prom/blackbox-exporter:v0.25.0
dns: 1.1.1.1
ports:
- 9115:9115
volumes:
- ./blackbox:/blackbox
networks:
- back-tier
command: --config.file=/blackbox/config.yml
grafana:
image: docker.io/grafana/grafana:11.3.0
healthcheck:
test:
- CMD
- wget
- --spider
- -q
- http://localhost:3000/api/health
interval: 30s
timeout: 10s
retries: 3
depends_on:
- prometheus
ports:
- 3000:3000
volumes:
- grafana_data:/var/lib/grafana:rw
- ./grafana/conf/provisioning/:/etc/grafana/provisioning/:ro
- ./grafana/conf/defaults.ini:/etc/grafana/grafana.ini:ro
- ${AWS_SHARED_CREDENTIALS_FILE:-~/.aws/credentials}:${AWS_SHARED_CREDENTIALS_FILE:-/home/grafana/.aws/credentials}:ro
environment:
- AWS_REGION
- AWS_DEFAULT_REGION
- AWS_ACCESS_KEY_ID
- AWS_SECRET_ACCESS_KEY
- AWS_SESSION_TOKEN
- AWS_PROFILE
- AWS_SHARED_CREDENTIALS_FILE
env_file:
- ./grafana/config.env
networks:
- back-tier
- front-tier
nginx:
image: docker.io/nginx:1.27.2
ports:
- 8080:80
networks:
- back-tier
- front-tier
volumes:
- ./nginx/html:/usr/share/nginx/html:ro
- ./nginx/etc/nginx/nginx.conf:/etc/nginx/nginx.conf:ro
# node-exporter:
# <<: *common
# image: quay.io/prometheus/node-exporter:latest
# volumes:
# - /proc:/host/proc:ro
# - /sys:/host/sys:ro
# - /:/rootfs:ro
# - /:/host:ro,rslave
# command:
# - '--path.rootfs=/host'
# - '--path.procfs=/host/proc'
# - '--path.sysfs=/host/sys'
# - --collector.filesystem.ignored-mount-points
# - "^/(sys|proc|dev|host|etc|rootfs/var/lib/docker/containers|rootfs/var/lib/docker/overlay2|rootfs/run/docker/netns|rootfs/var/lib/docker/aufs)($$|/)"
# ports:
# - 9100:9100
# networks:
# - back-tier
prometheus:
image: docker.io/prom/prometheus:v2.55.0
healthcheck:
test:
- CMD
- wget
- --spider
- -q
- http://localhost:9090/-/healthy
interval: 30s
timeout: 10s
retries: 3
volumes:
- ./prometheus/:/etc/prometheus/
- prometheus_data:/prometheus
extra_hosts:
- "node-exporter:host-gateway"
command:
- --config.file=/etc/prometheus/config.yml
- --storage.tsdb.path=/prometheus
- --web.console.libraries=/usr/share/prometheus/console_libraries
- --web.console.templates=/usr/share/prometheus/consoles
- --web.enable-lifecycle
ports:
- 9090:9090
networks:
- back-tier