zabbix监控业务容器状态

发布于:2024-12-19 ⋅ 阅读:(9) ⋅ 点赞:(0)

在使用docker运行业务时,我们难免也想用zabbix来监控容器是否是启动状态。自动化运维始终是作为运维的终极目标,同时告警也是必不可少好帮手。

我们以docker方式运行的zabbix-agent2 容器和其他业务容器该怎么去监控容器状态是否是UP


目前版本:zabbix6.0


方法一、

Zabbix 提供了一个 Docker 监控模板,它可以直接帮助您监控容器的状态。

在这里插入图片描述
这里边有一大堆的数据哦,写的满满当当。感兴趣的小伙伴可以研究下

方法二、

自己编写一个监控项,更推荐使用这种方式,监控项取值可以更精准更符合业务需求,也不会产生很多冗余数据。

1、配置 Zabbix Agent 在 Zabbix Agent 配置文件 /etc/zabbix/zabbix_agentd.conf 中添加一个 UserParameter,该参数将执行 Docker 命令来检查容器状态。

UserParameter=docker.container.up[*],docker inspect --format '{{.State.Running}}' $1 > /dev/null 2>&1 && echo 1 || echo 0


# docker inspect --format '{{.State.Running}}' $1:获取容器是否运行的状态
# > /dev/null 2>&1:将所有输出重定向到 /dev/null,避免输出干扰
# && echo 1 || echo 0:如果命令执行成功(即容器在运行),返回 1;如果命令失败(容器停止或不存在),返回 0
# $1 是一个占位符,它表示您将传递给这个监控项的参数(即容器的名称或 ID)。您只需要一个 UserParameter 配置,就可以监控任意容器的状态。

这个命令会检查指定容器是否在运行,运行返回 1 或 未运行返回 0。这样的作法是即使监控容器也挂掉了,还会有数据返回,配合触发器可以使我们尽早解决问题。

2、创建监控项
在这里插入图片描述
3、构建监控容器,或手动更改它
因为运行 Zabbix Agent 的容器默认可能无法直接访问宿主机的 Docker 引擎,我们必须做一些其他的更改,才可以让它正确的反馈监控值。

修改/var/run/docker.sock的权限

ls -l /var/run/docker.sock

srw-rw---- 1 root docker ...

更改挂载的权限(为什么要这么做:容器内的用户并不属于docker组,即使挂载了 /var/run/docker.sock,容器内的用户可能也没有权限访问它)

chmod 666 /var/run/docker.sock

运行zabbix-agent 容器

docker run -d \
    --name zabbix-agent2 \
    -v /var/run/docker.sock:/var/run/docker.sock \
    -v /etc/zabbix/zabbix_agent2.conf:/etc/zabbix/zabbix_agent2.conf \
    -e ZBX_DEBUGLEVEL=4 \
    --network="host" \
    --restart=always \
    registry.cn-hangzhou.aliyuncs.com/xxxx/xxxxx:zabbix-arm

以root用户进入容器内部并安装docker.io

docker exec -it -u root zabbix-agent2 /bin/bash

apt update

apt -y install docker.io

挂载和权限修改后,在容器内手动测试 docker inspect:

测试成功后可以将当前容器生成新的容器保存,方便下次直接可以使用