Docker中部署Alertmanager

在 Docker 中部署 Alertmanager(通常与 Prometheus 告警系统配合使用)的步骤如下:

一、拉取镜像prom/alertmanager

csharp 复制代码
docker pull prom/alertmanager

二、 创建 Alertmanager 配置文件

首先准备Alertmanager的配置文件 alertmanager.yml(如存放在 ./alertmanager/ 目录下):

csharp 复制代码
# ./alertmanager/alertmanager.yml
global:
  resolve_timeout: 5m
  smtp_smarthost: 'smtp.example.com:25'
  smtp_from: 'alertmanager@example.com'
route:
  group_by: ['alertname']
  group_wait: 10s
  group_interval: 5m
  repeat_interval: 3h
  receiver: 'email-notifications'
receivers:
- name: 'email-notifications'
  email_configs:
  - to: 'team@example.com'

三、创建 Docker 运行命令

使用以下命令启动 Alertmanager 容器:

csharp 复制代码
docker run -d \
  --name alertmanager \
  --network prometheus-net \  # 可选:与 Prometheus 同一网络
  -p 9093:9093 \             # 暴露 Alertmanager 默认端口
  -v $(pwd)/alertmanager/alertmanager.yml:/etc/alertmanager/alertmanager.yml \
  -v $(pwd)/alertmanager/data:/alertmanager \  # 持久化数据(如静默规则)
  prom/alertmanager:latest \
  --config.file=/etc/alertmanager/alertmanager.yml \
  --storage.path=/alertmanager/data

参数说明:

--network:如果与 Prometheus 容器互通,建议使用同一 Docker 网络。

-v:挂载配置文件和数据目录(确保本地目录存在)。

--config.file:指定配置文件路径(容器内路径)。

--storage.path:持久化数据存储路径。

四、验证部署

检查容器状态:

csharp 复制代码
docker ps | grep alertmanager

访问 Web 界面:

打开浏览器访问 http://<服务器IP>:9093,应看到 Alertmanager 的 Web UI。

五、集成 Prometheus

在 Prometheus 的配置文件 prometheus.yml 中添加 Alertmanager 的地址:

csharp 复制代码
alerting:
  alertmanagers:
  - static_configs:
    - targets: ["alertmanager:9093"]  # 若在同一 Docker 网络,可直接用容器名

重启 Prometheus 容器使配置生效。

六、使用 Docker Compose

创建 docker-compose.yml 文件简化管理:

csharp 复制代码
version: '3'
services:
  alertmanager:
    image: prom/alertmanager:latest
    container_name: alertmanager
    ports:
      - "9093:9093"
    volumes:
      - ./alertmanager/alertmanager.yml:/etc/alertmanager/alertmanager.yml
      - ./alertmanager/data:/alertmanager
    command:
      - '--config.file=/etc/alertmanager/alertmanager.yml'
      - '--storage.path=/alertmanager/data'
    restart: unless-stopped

启动服务:

csharp 复制代码
docker-compose up -d

通过以上步骤,Alertmanager 即可在 Docker 中运行并接收 Prometheus 的告警通知。根据实际需求调整配置文件中的路由规则和接收器(如 Webhook、Slack 等)。

常见问题

1)配置文件错误:

使用 --log.level=debug 参数启动容器,查看日志排查配置错误:

csharp 复制代码
docker logs alertmanager

2)持久化数据:

确保 data 目录挂载正确,否则重启后静默规则等数据会丢失。

3)网络互通:

若 Prometheus 无法连接 Alertmanager,检查两者是否在同一 Docker 网络

PS:需要笔记资料可以联系老师获取

VX:chuansinfo_sz

相关推荐
JoyCong199827 分钟前
高效远程协作指南:基于ToDesk的六大应用场景详解
运维·服务器·远程工作·远程操作
三不原则1 小时前
实战:混沌工程入门,模拟服务器宕机的故障演练
运维·kubernetes·chaos mesh
cws2004012 小时前
MFA双因素用户使用手册
运维·windows·网络安全·github·邮件·邮箱
weixin_462446232 小时前
使用 Python 脚本自动化管理 Docker 容器:启动、修改密码、删除及系统资源监控
python·docker·自动化·系统监控
溜达的大象2 小时前
Navidrome 打造专属无损音乐库,加载cpolar局域网外访问也能超丝滑
阿里云·docker·云原生·eureka
断水客3 小时前
搭建ARM LINUX 内核 QEMU 仿真调试环境
linux·运维·arm开发·嵌入式
fantasy5_53 小时前
深入理解 Linux 动静态库:制作、原理与加载机制
linux·运维·restful
weixin_307779133 小时前
面向通用矩阵乘法(GEMM)负载的GPU建模方法:原理、实现与多场景应用价值
运维·人工智能·线性代数·矩阵·gpu算力
不爱吃糖的程序媛3 小时前
OpenHarmony仓颉文档:全场景应用开发指南
运维·服务器
终端行者3 小时前
Nginx四层负载均衡配置 Stream模块使用
运维·nginx·负载均衡