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

配置文件(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"]

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"

安装 grafana

docker run \
        --name=grafana \
        -p 3000:3000 \
        --restart=always \
        grafana/grafana

安装 alertmanager

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

配置文件

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']
相关实践学习
通过可观测可视化Grafana版进行数据可视化展示与分析
使用可观测可视化Grafana版进行数据可视化展示与分析。
相关文章
|
10天前
|
弹性计算 Ubuntu Linux
阿里云服务器一键安装Docker社区版教程,基于系统运维管理OOS
阿里云服务器一键安装Docker社区版教程,基于系统运维管理OOS自动化部署。支持Ubuntu 22.04/20.04、CentOS 7.7-7.9及Alibaba Cloud Linux 3.2104 LTS。前提条件:ECS实例需运行中且有公网。步骤:选择Docker扩展并安装,验证成功通过命令`docker -v`查看版本号。
166 78
|
24天前
|
NoSQL 关系型数据库 应用服务中间件
docker基础篇:安装tomcat
docker基础篇:安装tomcat
161 64
|
14天前
|
NoSQL 关系型数据库 Redis
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
64 14
|
11天前
|
关系型数据库 MySQL 应用服务中间件
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
51 7
|
26天前
|
关系型数据库 MySQL 数据库
docker高级篇(大厂进阶):安装mysql主从复制
docker高级篇(大厂进阶):安装mysql主从复制
98 24
|
27天前
|
NoSQL 算法 Redis
docker高级篇(大厂进阶):安装redis集群
docker高级篇(大厂进阶):安装redis集群
100 24
|
25天前
|
Ubuntu Linux Docker
Ubuntu22.04上Docker的安装
通过以上详细的安装步骤和命令,您可以在Ubuntu 22.04系统上顺利安装
497 12
|
2月前
|
Prometheus 运维 监控
智能运维实战:Prometheus与Grafana的监控与告警体系
【10月更文挑战第26天】Prometheus与Grafana是智能运维中的强大组合,前者是开源的系统监控和警报工具,后者是数据可视化平台。Prometheus具备时间序列数据库、多维数据模型、PromQL查询语言等特性,而Grafana支持多数据源、丰富的可视化选项和告警功能。两者结合可实现实时监控、灵活告警和高度定制化的仪表板,广泛应用于服务器、应用和数据库的监控。
315 3
|
19天前
|
存储 数据采集 Prometheus
Grafana Prometheus Altermanager 监控系统
Grafana、Prometheus 和 Alertmanager 是一套强大的开源监控系统组合。Prometheus 负责数据采集与存储,Alertmanager 处理告警通知,Grafana 提供可视化界面。本文简要介绍了这套系统的安装配置流程,包括各组件的下载、安装、服务配置及开机自启设置,并提供了访问地址和重启命令。适用于希望快速搭建高效监控平台的用户。
93 20
|
15天前
|
Prometheus 监控 Cloud Native
Prometheus+Grafana监控Linux主机
通过本文的步骤,我们成功地在 Linux 主机上使用 Prometheus 和 Grafana 进行了监控配置。具体包括安装 Prometheus 和 Node Exporter,配置 Grafana 数据源,并导入预设的仪表盘来展示监控数据。通过这种方式,可以轻松实现对 Linux 主机的系统指标监控,帮助及时发现和处理潜在问题。
78 7