-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocker-stack-monitoring.yml
127 lines (121 loc) · 3.21 KB
/
docker-stack-monitoring.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
126
127
# -----------------------------------------
# Docker Swarm Monitoring Stack yaml
# Owner: Ahmet AKSIT <ahmetaksit@gmail.com>
# links: https://github.com/dockerAA/logging-and-monitoring
#------------------------------------------
version: '3.3'
services:
cadvisor:
image: google/cadvisor:latest
deploy:
mode: global
resources:
reservations:
memory: 50M
limits:
memory: 80M
volumes:
- /:/rootfs
- /var/run:/var/run
- /sys:/sys
- /var/lib/docker:/var/lib/docker
# ports:
# - 8080:8080
networks:
- monitor
node-exporter:
image: basi/node-exporter:v1.13.0
environment:
- HOST_HOSTNAME=/etc/host_hostname
volumes:
- /proc:/host/proc
- /sys:/host/sys
- /:/rootfs
- /etc/hostname:/etc/host_hostname
deploy:
mode: global
resources:
reservations:
memory: 20M
limits:
memory: 70M
command: '-collector.procfs /host/proc -collector.sysfs /host/sys -collector.filesystem.ignored-mount-points "^/(sys|proc|dev|host|etc)($$|/)" -collector.textfile.directory /etc/node-exporter/ -collectors.enabled="conntrack,diskstats,entropy,filefd,filesystem,loadavg,mdadm,meminfo,netdev,netstat,stat,textfile,time,vmstat,ipvs"'
networks:
- monitor
prometheus:
image: prom/prometheus:v1.8.2
deploy:
resources:
reservations:
memory: 500M
limits:
memory: 1500M
placement:
constraints: [node.role == manager]
configs:
- source: prometheus.yml
target: /etc/prometheus/prometheus.yml
- source: alert.rules
target: /etc/prometheus/alert.rules
volumes:
# - /data/prometheus/data:/prometheus
- type: volume
source: prometheus-data
target: /prometheus
volume:
nocopy: true
command:
- '-config.file=/etc/prometheus/prometheus.yml'
- '-storage.local.path=/prometheus'
- '-web.console.libraries=/usr/share/prometheus/console_libraries'
- '-web.console.templates=/usr/share/prometheus/consoles'
ports:
- 9070:9090
networks:
- monitor
grafana:
image: grafana/grafana:5.1.2
deploy:
resources:
reservations:
memory: 30M
limits:
memory: 200M
placement:
constraints: [node.role == manager]
environment:
- GF_SECURITY_ADMIN_PASSWORD=admin
volumes:
# - /data/grafana/data:/data/grafana/data
- type: volume
source: grafana-data
target: /data/grafana/data
volume:
nocopy: true
ports:
- 9030:3000
networks:
- monitor
volumes:
prometheus-data:
driver: local
driver_opts:
type: nfs
o: addr=172.16.18.11,rw
device: ":/docker01_mcA/docker/volumes/monitoring/prometheus-data"
grafana-data:
driver: local
driver_opts:
type: nfs
o: addr=172.16.18.11,rw
device: ":/docker01_mcA/docker/volumes/monitoring/grafana-data"
networks:
monitor:
# external: true
configs:
prometheus.yml:
file: config/prometheus/prometheus.yml
# external: true
alert.rules:
file: config/prometheus/alert.rules
# external: true