docker 安装 prometheus、grafana 和 alertmanager

本文涉及的产品
可观测监控 Prometheus 版,每月50GB免费额度
可观测可视化 Grafana 版,10个用户账号 1个月
简介: docker 安装 prometheus、grafana 和 alertmanager

安装 prometheus

docker run \
        --name=prometheus \
        --volume=/data/app/prometheus/config/:/etc/prometheus/ \
        --volume=/etc/localtime:/etc/localtime \
        --volume=/data/app/prometheus/data:/prometheus \
        --network=host \
        --expose=9090/tcp \
        --restart=always \
        prom/prometheus \
        --config.file=/etc/prometheus/prometheus.yml --web.enable-lifecycle
AI 代码解读

配置文件(prometheus)

#my global config
global:
  scrape_interval:     15s # Set the scrape interval to every 15 seconds. Default is every 1 minute.
  evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute.
  # scrape_timeout is set to the global default (10s).
# Alertmanager configuration
alerting:
  alertmanagers:
  - static_configs:
    - targets:
       - XXX:9093
rule_files:
  - /etc/prometheus/rules.yml
scrape_configs:
  - job_name: 'XXX'
    scrape_interval: 10s
    file_sd_configs:
      - refresh_interval: 1m
        files: ["/etc/prometheus/json/*.json"]
AI 代码解读

rules配置文件(sample)

groups:
- name: test
  rules:
  - alert: InstanceDown
    expr: up == 0
    for: 5s
    labels:
      severity: fire
      alertName: Instance
    annotations:
      summary: "Target:{{ $labels.instance }} Down"
      description: "{{ $labels.instance }} has been down for more than 5s"

  - alert: CPUUsage 90%
    expr: 100 - (avg by (instance,hostName,hostIp)(irate(node_cpu_seconds_total{mode="idle"}[1m]) )) * 100 > 90
    for: 1m
    labels:
      severity: fire
      alertName: CPU
    annotations:
      summary: "Target:{{ $labels.instance }} CPU使用率超过90%"
      description: "{{ $labels.instance }} CPU使用率超过90% 已经持续1m"

  - alert: CPUUsage 85%
    expr: 100 - (avg by (instance,hostName,hostIp)(irate(node_cpu_seconds_total{mode="idle"}[1m]) )) * 100 > 85
    for: 1m
    labels:
      severity: critical
      alertName: CPU
    annotations:
      summary: "Target:{{ $labels.instance }} CPU使用率超过85%"
      description: "{{ $labels.instance }} CPU使用率超过85% 已经持续1m"

  - alert: CPUUsage 70%
    expr: 100 - (avg by (instance,hostName,hostIp)(irate(node_cpu_seconds_total{mode="idle"}[1m]) )) * 100 > 70
    for: 5m
    labels:
      severity: warning
      alertName: CPU
    annotations:
      summary: "Target:{{ $labels.instance }} CPU使用率超过70%"
      description: "{{ $labels.instance }} CPU使用率超过70% 已经持续5m"

  - alert: MEMUsage 90%
    expr: (node_memory_MemTotal_bytes - (node_memory_MemFree_bytes+node_memory_Buffers_bytes+node_memory_Cached_bytes )) / node_memory_MemTotal_bytes * 100 > 90
    for: 1m
    labels:
      severity: fire
      alertName: MEM
    annotations:
      summary: "Target:{{ $labels.instance }} 内存使用率超过90%"
      description: "{{ $labels.instance }} 内存使用率超过90% 已经持续1m"

  - alert: MEMUsage 80%
    expr: (node_memory_MemTotal_bytes - (node_memory_MemFree_bytes+node_memory_Buffers_bytes+node_memory_Cached_bytes )) / node_memory_MemTotal_bytes * 100 > 80
    for: 1m
    labels:
      severity: critical
      alertName: MEM
    annotations:
      summary: "Target:{{ $labels.instance }} 内存使用率超过80%"
      description: "{{ $labels.instance }} 内存使用率超过80% 已经持续1m"

  - alert: MEMUsage 70%
    expr: (node_memory_MemTotal_bytes - (node_memory_MemFree_bytes+node_memory_Buffers_bytes+node_memory_Cached_bytes )) / node_memory_MemTotal_bytes * 100 > 70
    for: 5m
    labels:
      severity: warning
      alertName: MEM
    annotations:
      summary: "Target:{{ $labels.instance }} 内存使用率超过70%"
      description: "{{ $labels.instance }} 内存使用率超过70% 已经持续5m"

  - alert: DISKUsage 90%
    expr: (node_filesystem_size_bytes - node_filesystem_avail_bytes) / node_filesystem_size_bytes * 100 > 90
    for: 1m
    labels:
      severity: fire
      alertName: DISK
    annotations:
      summary: "Target:{{ $labels.instance }} 磁盘使用率超过90%"
      description: "{{ $labels.instance }} 磁盘使用率超过90% 已经持续1m"

  - alert: DISKUsage 85%
    expr: (node_filesystem_size_bytes - node_filesystem_avail_bytes) / node_filesystem_size_bytes * 100 > 80
    for: 1m
    labels:
      severity: critical
      alertName: DISK
    annotations:
      summary: "Target:{{ $labels.instance }} 磁盘使用率超过80%"
      description: "{{ $labels.instance }} 磁盘使用率超过80% 已经持续1m"

  - alert: DISKUsage 70%
    expr: (node_filesystem_size_bytes - node_filesystem_avail_bytes) / node_filesystem_size_bytes * 100 > 70
    for: 5m
    labels:
      severity: warning
      alertName: DISK
    annotations:
      summary: "Target:{{ $labels.instance }} 磁盘使用率超过70%"
      description: "{{ $labels.instance }} 磁盘使用率超过70% 已经持续5m"
AI 代码解读

安装 grafana

docker run \
        --name=grafana \
        -p 3000:3000 \
        --restart=always \
        grafana/grafana
AI 代码解读

安装 alertmanager

docker run \
        --name=alertmanager \
        --volume=/data/app/alertmanager/conf/alertmanager.yml:/etc/alertmanager/alertmanager.yml \
        --network=host \
        --restart=no \
        prom/alertmanager
AI 代码解读

配置文件

global:
  resolve_timeout: 30m

route:
  group_by: ['instance']
  group_wait: 1s
  group_interval: 1s
  repeat_interval: 5m
  receiver: "webhook"
receivers:
- name: "webhook"
  webhook_configs:
  - url: 'http://xxx/xx/xx/'
    send_resolved: true
inhibit_rules:
  - source_match:
      severity: 'fire'
    target_match:
      severity: 'critical'
    equal: ['alertName', 'instance']
  - source_match:
      severity: 'critical'
    target_match:
      severity: 'warning'
    equal: ['alertName','alertName']
AI 代码解读
相关实践学习
通过可观测可视化Grafana版进行数据可视化展示与分析
使用可观测可视化Grafana版进行数据可视化展示与分析。
相关文章
除了Prometheus,还有哪些工具可以监控Docker Swarm集群的资源使用情况?
除了Prometheus,还有哪些工具可以监控Docker Swarm集群的资源使用情况?
253 79
|
22天前
|
Docker中安装MongoDB并配置数据、日志、配置文件持久化。
现在,你有了一个运行在Docker中的MongoDB,它拥有自己的小空间,对高楼大厦的崩塌视而不见(会话丢失和数据不持久化的问题)。这个MongoDB的数据、日志、配置文件都会妥妥地保存在你为它精心准备的地方,天旋地转,它也不会失去一丁点儿宝贵的记忆(即使在容器重启后)。
116 4
MyEMS开源系统安装之Linux/macOS上的DOcker
本指南详细介绍了如何在Linux/macOS上使用Docker部署MyEMS系统。主要内容包括:前置条件(如安装Docker、npm和MySQL),以及分步骤部署各个组件(如myems-api、myems-admin、myems-modbus-tcp等)。每个步骤涵盖源代码复制、环境配置、镜像构建、容器运行及日志管理等操作,并提供了多平台构建的支持。最后,指南还说明了默认端口和登录凭据,帮助用户快速启动并访问MyEMS的管理界面和Web界面。
77 1
Docker 安装常用软件相关命令
本文介绍了在CentOS 7.9系统上安装Docker的详细步骤,包括添加阿里云镜像源、安装Docker及相关组件、启动服务以及配置镜像加速。同时,还展示了如何通过Docker安装MySQL 5.7版本数据库,涵盖拉取镜像、创建数据目录、运行容器及配置挂载点等操作,并提供验证安装成功的命令和截图。适合需要部署Docker与MySQL环境的用户参考。
217 5
安装Docker
常见操作系统安装docker步骤
214 15
|
2月前
|
在openEuler 22.03 LTS上安装Docker CE和Docker Compose
以上就是在openEuler 22.03 LTS上安装Docker CE和Docker Compose的过程。希望这个指南能帮助你顺利完成安装。
481 12
Prometheus+Grafana(docker安装)
本文档详细介绍了如何使用Docker容器快速部署Prometheus监控系统和Grafana数据可视化平台。该方案适用于需要快速搭建监控环境的开发测试场景,具备部署简单、资源占用低、易于维护等特点。
智能运维实战:Prometheus与Grafana的监控与告警体系
【10月更文挑战第26天】Prometheus与Grafana是智能运维中的强大组合,前者是开源的系统监控和警报工具,后者是数据可视化平台。Prometheus具备时间序列数据库、多维数据模型、PromQL查询语言等特性,而Grafana支持多数据源、丰富的可视化选项和告警功能。两者结合可实现实时监控、灵活告警和高度定制化的仪表板,广泛应用于服务器、应用和数据库的监控。
786 3
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问