mirror of
https://github.com/yeasy/docker_practice.git
synced 2026-03-11 12:21:17 +00:00
- Enforce Level 1-3 structural numbering based on SUMMARY.md hierarchy - Remove structural numbering from Level 4+ headings - Eliminate single child headings by converting to bold text - Auto-inject summary text for headings with multiple children missing intro text - Exclude Appendix chapters from structural numbering - Avoid modifying code block contents - Add script to detect non-standard English usage in headers
2.6 KiB
2.6 KiB
18.1 Prometheus + Grafana
Prometheus 和 Grafana 是目前最流行的开源监控组合,前者负责数据采集与存储,后者负责数据可视化。
Prometheus 是一个开源的系统监控和报警工具包。它受 Google Borgmon 的启发,由 SoundCloud 在 2012 年创建。
18.1.1 架构简介
Prometheus 的主要组件包括:
- Prometheus Server:核心组件,负责收集和存储时间序列数据。
- Exporters:负责向 Prometheus 暴露监控数据 (如 Node Exporter,cAdvisor)。
- Alertmanager:处理报警发送。
- Pushgateway:用于支持短生命周期的 Job 推送数据。
18.1.2 快速部署
我们可以使用 Docker Compose 快速部署一套 Prometheus + Grafana 监控环境。
1。准备配置文件
创建 prometheus.yml:
global:
scrape_interval: 15s
scrape_configs:
- job_name: 'prometheus'
static_configs:
- targets: ['localhost:9090']
- job_name: 'node-exporter'
static_configs:
- targets: ['node-exporter:9100']
- job_name: 'cadvisor'
static_configs:
- targets: ['cadvisor:8080']
2。编写 Docker Compose 文件
创建 compose.yaml (或 docker-compose.yml):
services:
prometheus:
image: prom/prometheus:latest
volumes:
- ./prometheus.yml:/etc/prometheus/prometheus.yml
ports:
- "9090:9090"
networks:
- monitoring
grafana:
image: grafana/grafana:latest
ports:
- "3000:3000"
environment:
- GF_SECURITY_ADMIN_PASSWORD=admin
networks:
- monitoring
depends_on:
- prometheus
node-exporter:
image: prom/node-exporter:latest
ports:
- "9100:9100"
networks:
- monitoring
cadvisor:
image: gcr.io/cadvisor/cadvisor:latest
ports:
- "8080:8080"
volumes:
- /:/rootfs:ro
- /var/run:/var/run:ro
- /sys:/sys:ro
- /var/lib/docker/:/var/lib/docker:ro
networks:
- monitoring
networks:
monitoring:
3。启动服务
运行以下命令:
$ docker compose up -d
启动后,访问以下地址:
- Prometheus:
http://localhost:9090 - Grafana:
http://localhost:3000(默认账号密码:admin/admin)
18.1.3 配置 Grafana 面板
- 在 Grafana 中添加 Prometheus 数据源,URL 填写
http://prometheus:9090。 - 导入现成的 Dashboard 模板,例如 Node Exporter Full (ID:1860) 和 Docker Container (ID:193)。
这样,你就拥有了一个直观的容器监控大屏。