-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.observe.yml
More file actions
127 lines (120 loc) · 3.33 KB
/
docker-compose.observe.yml
File metadata and controls
127 lines (120 loc) · 3.33 KB
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 Compose for Observability Stack
# Monitoring and logging infrastructure for New Tab application
# Run with: docker-compose -f docker-compose.observe.yml up -d
services:
# Container metrics collection
cadvisor:
image: gcr.io/cadvisor/cadvisor:v0.47.0
container_name: newtab-cadvisor
restart: unless-stopped
ports:
- "8080:8080"
volumes:
- /:/rootfs:ro
- /var/run:/var/run:ro
- /sys:/sys:ro
- /var/lib/docker/:/var/lib/docker:ro
- /dev/disk/:/dev/disk:ro
privileged: true
devices:
- /dev/kmsg:/dev/kmsg
networks:
- monitoring
# Metrics collection and storage
prometheus:
image: prom/prometheus:v2.45.0
container_name: newtab-prometheus
restart: unless-stopped
ports:
- "9090:9090"
command:
- '--config.file=/etc/prometheus/prometheus.yml'
- '--storage.tsdb.path=/prometheus'
- '--web.console.libraries=/etc/prometheus/console_libraries'
- '--web.console.templates=/etc/prometheus/consoles'
- '--storage.tsdb.retention.time=15d'
- '--web.enable-lifecycle'
volumes:
- ./config/prometheus:/etc/prometheus
- prometheus_data:/prometheus
networks:
- monitoring
depends_on:
- cadvisor
# Visualization and dashboards
grafana:
image: grafana/grafana:10.0.0
container_name: newtab-grafana
restart: unless-stopped
ports:
- "3000:3000"
environment:
- GF_SECURITY_ADMIN_PASSWORD=${GRAFANA_ADMIN_PASSWORD:-admin123}
- GF_USERS_ALLOW_SIGN_UP=false
- GF_INSTALL_PLUGINS=grafana-clock-panel,grafana-simple-json-datasource
volumes:
- grafana_data:/var/lib/grafana
- ./config/grafana/provisioning:/etc/grafana/provisioning
- ./config/grafana/dashboards:/var/lib/grafana/dashboards
networks:
- monitoring
depends_on:
- prometheus
# Log aggregation (optional)
loki:
image: grafana/loki:2.8.0
container_name: newtab-loki
restart: unless-stopped
ports:
- "3100:3100"
command: -config.file=/etc/loki/local-config.yaml
volumes:
- ./config/loki:/etc/loki
- loki_data:/loki
networks:
- monitoring
# Log collection agent
promtail:
image: grafana/promtail:2.8.0
container_name: newtab-promtail
restart: unless-stopped
volumes:
- ./logs:/var/log/newtab:ro
- ./config/promtail:/etc/promtail
- /var/lib/docker/containers:/var/lib/docker/containers:ro
- /var/run/docker.sock:/var/run/docker.sock
command: -config.file=/etc/promtail/config.yml
networks:
- monitoring
depends_on:
- loki
# Node metrics (system-level monitoring)
node-exporter:
image: prom/node-exporter:v1.6.0
container_name: newtab-node-exporter
restart: unless-stopped
ports:
- "9100:9100"
command:
- '--path.procfs=/host/proc'
- '--path.rootfs=/rootfs'
- '--path.sysfs=/host/sys'
- '--collector.filesystem.mount-points-exclude=^/(sys|proc|dev|host|etc)($$|/)'
volumes:
- /proc:/host/proc:ro
- /sys:/host/sys:ro
- /:/rootfs:ro
networks:
- monitoring
networks:
monitoring:
driver: bridge
name: monitoring
external: true
volumes:
prometheus_data:
name: newtab-prometheus-data
grafana_data:
name: newtab-grafana-data
loki_data:
name: newtab-loki-data