如何使用 Zabbix 监控工具监控 Docker 容器
Docker可以说是最受欢迎的DevOps工具之一,它使在容器内开发、部署和交付应用程序变得容易。
容器化的概念涉及到容器镜像的使用,这些是小型、轻量级、自包含的可执行包,其中包含运行应用程序所需的一切,包括源代码、库、依赖项和配置文件。
这样,应用程序几乎可以在任何计算机环境中运行;传统 IT 基础架构、云和无数 Linux / UNIX 版本。
容器监控可帮助运营团队识别潜在问题并及时解决,容器监控包括捕获基本指标,例如 CPU 使用率、内存使用率、容器大小和带宽使用率等,此外,您可以收集实时日志,这些日志对调试很有用,并在需要扩展时提醒 IT 团队。
Zabbix是一种流行的 IT 基础设施监控工具,它可以密切关注您环境中的几乎所有元素,包括服务器等物理设备和路由器和交换机等网络设备,它还可以监控应用程序、服务和数据库。
在本文中,我们将向您展示如何使用Linux 中的Zabbix监控工具来监控Docker容器。
要求
在开始之前,您需要具备以下条件:
首先,确保你有两个节点——第一个节点是 Zabbix 服务器,这是我们将控制Docker服务器remote 的节点。
第二个节点是安装Docker的Docker服务器,这是我们将运行 Docker 容器并监控容器活动的节点。
因此,请确保您已经配置了 sudo 用户,可以通过 SSH 访问您的Docker服务器节点。
设置到位后,您现在可以卷起袖子了!
第 1 步:在 Linux 上安装 Zabbix-Agent
要在远程服务器上监控Docker容器,您需要安装Zabbix Agent,它是目标节点上的分布式监控代理,用于主动监控系统指标和其他应用程序。
首先,您需要在Docker节点上安装Zabbix存储库。
在 Ubuntu 20.04 上
$ sudo wget https://repo.zabbix.com/zabbix/5.4/ubuntu/pool/main/z/zabbix-release/zabbix-release_5.4-1+ubuntu20.04_all.deb
$ sudo dpkg -i zabbix-release_5.4-1+ubuntu20.04_all.deb
$ sudo apt update
$ sudo apt install zabbix-agent2
在基于 RHEL 的发行版上
$ sudo rpm -Uvh https://repo.zabbix.com/zabbix/5.4/rhel/8/x86_64/zabbix-release-5.4-1.el8.noarch.rpm
$ sudo dnf update
$ sudo dnf install zabbix-agent
在 Debian 11 上
$ sudo wget https://repo.zabbix.com/zabbix/5.4/debian/pool/main/z/zabbix-release/zabbix-release_5.4-1%2Bdebian11_all.deb
$ sudo dpkg -i zabbix-release_5.4-1%2Bdebian11_all.deb
$ sudo apt update
$ sudo apt install zabbix-agent2
在 Debian 10 上
$ sudo wget https://repo.zabbix.com/zabbix/5.4/debian/pool/main/z/zabbix-release/zabbix-release_5.4-1%2Bdebian10_all.deb
$ sudo dpkg -i zabbix-release_5.4-1%2Bdebian10_all.deb
$ sudo apt update
$ sudo apt install zabbix-agent2
第 2 步:在 Linux 中配置 Zabbix-Agent
默认情况下,Zabbix代理设置为将指标发送到安装它的同一主机上的Zabbix服务器,由于我们的目标是监控远程服务器上的docker容器,因此需要一些额外的配置。
因此,访问Zabbix代理配置文件。
$ sudo vim /etc/zabbix/zabbix_agent2.conf
配置文件包含指定指标发送到的地址、用于连接的端口等的设置。在大多数情况下,默认设置可以正常工作。
要配置Zabbix代理以将指标发送到Zabbix服务器,请找到配置为将指标发送到环回地址或仅发送到主机系统本身的指令。
Server=127.0.0.1
设置地址以反映 Zabbix 服务器地址
Server=zabbix-server-IP
此外,转到“ Active Controls ”并将指令更改为指向 Zabbix 服务器的 IP 地址。
ServerActive = zabbix-server-IP
确保相应地调整 Docker 服务器主机名。我的 Docker 服务器主机名是Ubuntu20。
Hostname=Ubuntu20
然后保存更改并退出 Zabbix 配置文件。
为了让 Zabbix agent 时刻关注 Docker 容器,您需要将默认安装的 Zabbix 用户添加到 docker 组中。
$ sudo usermod -aG docker zabbix
要应用对配置文件所做的更改,请重新启动 Zabbix-agent 服务并允许它在系统启动时启动。
$ sudo systemctl restart zabbix-agent2
$ sudo systemctl enable zabbix-agent2
确认Zabbix agent的运行状态如下。
$ sudo systemctl status zabbix-agent2
查看 Zabbix 代理的状态
代理 Zabbix 侦听端口10050,如果您正在运行 UFW 防火墙或 firewalld,请考虑按如下方式打开端口。
在 UFW 防火墙上
$ sudo ufw allow 10050/tcp
$ sudo ufw reload
在防火墙上
$ sudo firewall-cmd --add-port=10050/tcp --permanent
$ sudo firewall-cmd --reload
伟大的!我们现在已经完成了一半,Zabbix 代理现在可以将容器的Docker指标发送到 Zabbix 服务器。
在下一步中,我们将把Docker服务器添加到Zabbix Web 界面并监控 Docker 容器。
第 2 步:在Zabbix服务器上添加docker进行监控
要监控远程主机,您需要通过浏览器将其添加到Zabbix服务器仪表板,Zabbix 为各种服务和应用程序提供了无数的模板,我们将适当的模型连接到 Docker 主机以专门监控容器,但首先,登录 Zabbix 服务器登录页面。
http://zabbix-server-ip/zabbix
Zabbix访问
登录后,转到右侧边栏并单击“配置”,然后单击“主机”。
Zabbix 主机配置
在右上角,单击“创建主机”。
Zabbix 创建主机
填写Docker服务器详细信息,如主机名和可见名称,对于组,输入“ Docker Groups ”(每个主机必须与一个组关联)。
在“接口”标签下单击“添加”,然后在出现的菜单中选择“代理”。
将主机添加到 Zabbix 监控
然后,输入 Docker 服务器的私有 IP 地址并确保端口设置为10050。
将 Docker 服务器添加到 Zabbix
然后,单击模板选项卡,在“连接新模板”部分,指定“ Zabbix Agent 2 Docker ”,然后单击“添加按钮”。
将 Zabbix 模型连接到 Docker
当您单击“添加”按钮时,远程 Docker 主机将按照指示自动添加。
Zabbix Docker 监控
此时,Zabbix 服务器正在监视您的 Docker 服务器,在下一步中,我们将部署一个容器并检查可以跟踪哪些指标。
第 4 步:在 Zabbix Monitoring 中监控 Docker 指标
为了开始跟踪Docker指标,我们将启动一个测试容器,然后,返回到您的Docker服务器并启动一个容器。
在此示例中,我们将拉取一个Ubuntu容器映像并创建一个名为docker_test_container的容器。然后我们将使用该-it选项访问 shell ,整个操作命令如下。
$ sudo docker run --name docker_test_container -it ubuntu bash
在 Docker 中创建 Ubuntu 容器镜像
您可以尝试一些雄心勃勃的事情,例如安装Apache或Maria DB 之类的软件包,以生成一些指标,例如 CPU 使用率和网络流量。
现在回到Zabbix服务器控制面板,单击“监控”,然后单击“主机”,单击您的 Docker 服务器名称,然后在出现的菜单选项中,选择“最新数据”。
Zabbix监控主机
部署容器几分钟后,Zabbix 服务器将检测容器并开始填充一些统计信息。
Zabbix 监控 Docker 主机
您还可以通过单击“主机”页面上的“Docker 服务器选项”“图形”按钮来查看各种容器指标的图形。您可以在下方看到 CPU 和内存使用指标。
Zabbix Docker 性能监视器
为了模拟容器崩溃,我们将通过在容器 shell 中运行以下命令意外退出容器。
# exit 2
这意味着我们已经终止了容器,错误代码为 2,这会记录在容器元数据中。要查看警告,请转到左侧边栏并单击“监控”,然后单击“控制面板”。
警告出现在下方。
Zabbix Docker 警报
要修复错误,只需重新启动容器即可。
$ sudo docker start docker_test_container