使用 Docker 安装 Zabbix,并配置自定义监控项

本文详细介绍了如何在Docker环境下安装Zabbix,并配置自定义Nginx监控项。首先,通过Docker安装Zabbix Server、Database Storage、Web Interface和Agent,然后开启自定义监控项,编写Nginx监控脚本,实现对Nginx状态的全面监控。文章还涵盖了Zabbix的工作原理和主要组件,以及安装和验证过程。
摘要由CSDN通过智能技术生成

一、Zabbix 简介

Zabbix 可以用来监控各种网络参数,来保证服务器和系统的安全运行。并且 Zabbix 还提供了灵活的通知机制,以此来让系统管理员快速定位/解决存在的各种问题。是一个基于 Web 界面提供的分布式系统监控以及网络监控功能的企业级开源解决方案。

1.监控功能

  • 主机性能监控、网络设备性能监控、数据库性能监控、多种告警方式、详细的报表图。
  • 监控主机,我们可以使用 Zabbix 提供的 Agent 软件,来监控 Linux、Windows、FreeBSD 等系统。
  • 监控网络设备,我们可以通过 Zabbix 支持的 SNMP 协议来进行监控(SSH 协议不常用)

1)监控对象

  • 设备:服务器,路由器,交换机。
  • 软件:OS,网络,应用程序。

2)主机性能指标监控

  • 故障监控:宕机,服务不可用,主机不可达。

2.Zabbix 工作原理

首先,我们需要在被监控的主机上安装 Agent 软件,用来收集当前服务器的各项数据信息,并发送给监控端,当监控端接收到 Agent 发送过来的信息后,会将数据存储到数据库中,接着通过 Web 界面来将数据在前端页面上进行展示和绘图。


这里 Agent 收集数据分为 主动和被动 两种模式:

  • 主动: 客户端通过连接监控端的 10051 端口,来主动的将收集到的信息推送给监控端。
  • 被动: 监控端定时的通过连接客户端的 10050 端口进行通信,来收集客户端的各项数据信息。

Zabbix 默认使用的模式为被动模式,也就是说当我们需要监控的主机数量较多时,可能会影响到监控端的性能。因为监控端会定时的通过连接客户端的端口进行数据收集,所以我们可以 选择性的配置部分主机为主动模式,来减少监控端的性能压力。

3.Zabbix 组件

组件作用
Zabbix Server用于接收 Agent 发送过来的信息,所有的配置、数据统计、数据操作都是由它组织进行
Database Storage用于存储所有的配置信息以及收集的数据信息
Web InterfaceZabbix 的 GUI 接口,可以用于界面展示(一般和 Server 运行在用一台主机上)
Agent用于采集本地的数据信息,也就是所谓的被监控端
Proxy可选组件,通常用于分布式监控架构;相当于是一个代理的 Server,用来收集 Agent 部分数据,并转发给监控端

4.Zabbix 进程

  1. Sender:用于发送数据给 Server 或者 Proxy,通常用于耗时比较长的检查;
  2. Get:Zabbix 命令,主要用于排查使用,可以在监控端上执行,来获取被监控端的信息;
  3. Agent:客户端守护进程,用于收集当前主机的数据信息,如:CPU 负载、内存的使用情况等;
  4. Proxy:代理守护进程,相当于是一个中转站,可以将收集到的数据信息 主动/被动 的提交到监控端上;
  5. Server:监控端守护进程,用于接收 Agent Get Sender Proxy Java_Gateway 提供的数据。

因为 Zabbix 并不能直接监控 Java 应用,所以在 Zabbix 2.0 后推出 Java_Gateway 代理进程,使我们可以监控 Java 应用。

二、使用 Zabbix 配置自定义监控项

  • 我们下面采用的是 docker-compose 方式安装,物理安装可以看我前面写的这篇文章:传送门

1.安装 Zabbix

1)安装 Docker

[root@Zabbix ~]# wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
[root@Zabbix ~]# yum -y install epel-release
[root@Zabbix ~]# yum -y install yum-utils device-mapper-persistent-data lvm2
[root@Zabbix ~]# yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo
[root@Zabbix ~]# yum -y install docker-ce-19.03.12 docker-ce-cli-19.03.12
[root@Zabbix ~]# systemctl enable docker --now

2)安装 Docker-Compose

[root@Zabbix ~]# wget "https://github.com/docker/compose/releases/download/v2.3.2/docker-compose-$(uname -s)-$(uname -m)" -O /usr/local/bin/docker-compose	
[root@Zabbix ~]# chmod +x /usr/local/bin/docker-compose
[root@Zabbix ~]# docker-compose --version

3)安装 Agent

[root@Zabbix ~]# rpm -ivh http://repo.zabbix.com/zabbix/5.4/rhel/7/x86_64/zabbix-agent-5.4.8-1.el7.x86_64.rpm
[root@Zabbix ~]# egrep -v '^$|#' zabbix_agentd.conf 
PidFile=/var/run/zabbix/zabbix_agentd.pid
LogFile=/var/log/zabbix/zabbix_agentd.log
LogFileSize=0
Server=127.0.0.1
ServerActive=127.0.0.1
Hostname=Zabbix server
Include=/etc/zabbix/zabbix_agentd.d/*.conf
[root@Zabbix ~]# systemctl enable zabbix-agent --now

4)安装 Zabbix

[root@Zabbix ~]# mkdir -p /app/zabbix
[root@Zabbix ~]# cd /app/zabbix/
[root@Zabbix zabbix]# cat <<END > docker-compose.yml
version: "3"
services:
  mysql-server:
    image: mysql:5.7
    ports:
      - "3306:3306"
    volumes:
      - "/app/mysql:/var/lib/mysql"				# 配置数据卷 (防止监控数据丢失)
    environment:
      MYSQL_ROOT_PASSWORD: 123123
      TZ: Asia/Shanghai
    command: --character-set-server=utf8 --collation-server=utf8_bin
    restart: always
  zabbix-server:
    image: zabbix/zabbix-server-mysql:5.4.8-centos
    environment:
      DB_SERVER_HOST: 127.0.0.1
      DB_SERVER_PORT: 3306
      MYSQL_DATABASE: zabbix
      MYSQL_USER: root
      MYSQL_PASSWORD: 123123
      TZ: Asia/Shanghai
    depends_on:
      - mysql-server
    restart: always
    network_mode: "host"						# 使用主机网络
  zabbix-web:
    image: zabbix/zabbix-web-nginx-mysql:5.4.8-centos
    ports:
      - "8000:8080"								# Zabbix WebUI 映射端口
    volumes:									# 当在 Web 界面配置成中文后,监控界面会出现乱码
      - "./simkai.ttf:/usr/share/zabbix/assets/fonts/DejaVuSans.ttf"
    environment:
      DB_SERVER_HOST: mysql-server
      DB_SERVER_PORT: 3306
      MYSQL_DATABASE: zabbix
      MYSQL_USER: root
      MYSQL_PASSWORD: 123123
      TZ: Asia/Shanghai
      ZBX_SERVER_HOST: 192.168.1.1
    depends_on:
      - mysql-server
      - zabbix-server
    restart: always
END
[root@Zabbix zabbix]# docker-compose up -d
[root@Zabbix zabbix]# docker-compose ps  
  • simkai.ttf 字体,你们可以在自己电脑上的这个 C:\Windows\Fonts 路径找到。

5)验证:http://192.168.1.1:8000(账号:Admin/zabbix
在这里插入图片描述

  • 界面上出现:zabbix server is not running: the information displayed may not be current 报错;
  • 原因可能是因为我们 docker-compose 文件中的 ZBX_SERVER_HOST 变量配置的值不是 Zabbix Server 的 IP 地址导致的。

我上面报错是为了让你们看下效果,如果你们出现如上配置,按照我的配置修改即可。


配置中文
在这里插入图片描述

2.开启自定义监控项

[root@Zabbix ~]# echo "UnsafeUserParameters=1" >> /etc/zabbix/zabbix_agentd.conf 

3.编写 Nginx 自定义监控脚本

[root@Zabbix ~]# yum -y install nginx
[root@Zabbix ~]# cat <<END > /etc/nginx/conf.d/status.conf
server {
    listen 80;
    server_name 127.0.0.1;
    location /status {
        stub_status on;
        allow 127.0.0.1;
        allow 192.168.1.0/24;
        deny all;
    }
}
END

1)编写自定义监控脚本

[root@Zabbix ~]# mkdir /etc/zabbix/scripts
[root@Zabbix ~]# vim /etc/zabbix/scripts/nginx_status.sh
#!/bin/bash
HOST="127.0.0.1"
PORT="80"
# 监控 Nginx 进程是否存在
function Ping {
    /sbin/pidof nginx | wc -l
}
# 监控 Nginx 状态信息
function Active {
    /usr/bin/curl "http://$HOST:$PORT/status" 2> /dev/null | grep "Active" | awk '{print $NF}'
}
function Reading {
    /usr/bin/curl "http://$HOST:$PORT/status" 2> /dev/null | grep "Reading" | awk '{print $2}'
}
function Writing {
    /usr/bin/curl "http://$HOST:$PORT/status" 2> /dev/null | grep "Writing" | awk '{print $4}'
}
function Waiting {
    /usr/bin/curl "http://$HOST:$PORT/status" 2> /dev/null | grep "Waiting" | awk '{print $6}'
}
function Server {
    /usr/bin/curl "http://$HOST:$PORT/status" 2> /dev/null | awk NR==3 | awk '{print $1}'
}
function Accepts {
    /usr/bin/curl "http://$HOST:$PORT/status" 2> /dev/null | awk NR==3 | awk '{print $2}'
}
function Requests {
    /usr/bin/curl "http://$HOST:$PORT/status" 2> /dev/null | awk NR==3 | awk '{print $3}'
}
# 执行 function
$1
[root@Zabbix ~]# chmod +x /etc/zabbix/scripts/nginx_status.sh

2)定义监控脚本

[root@Zabbix ~]# cat <<"END" > /etc/zabbix/zabbix_agentd.d/nginx_status.conf
UserParameter=nginx.status[*],/etc/zabbix/scripts/nginx_status.sh $1
END
[root@Zabbix ~]# systemctl restart zabbix-agent

3)验证

[root@Zabbix ~]# docker exec -it zabbix-zabbix-server-1 /bin/bash

在这里插入图片描述

创建模板
在这里插入图片描述

创建应用集
在这里插入图片描述

创建监控项
在这里插入图片描述

因为在我们的监控脚本中,一共定义了 8 个监控项,所以我们上面也要创建 8 个监控项,重复上面操作,创建出对应的即可。
在这里插入图片描述

给我们的监控项创建图形
在这里插入图片描述

将 Nginx 模板加入到主机中
在这里插入图片描述

查看监控图
在这里插入图片描述
其实 Zabbix 的自定义监控项就是由 key/value 的形式组成。即,我们只需要把要监控的数据定义成一个 valuekey 里面的值就是我们想要监控的数据,那么也就是说,当我们定时的查找这个 key 对应的值,便可以得到监控数据。

Docker可以用来轻松地在容器中运行Zabbix 6.0监控系统。下面是安装Zabbix 6.0到Docker容器的基本步骤: 1. **拉取Zabbix Docker镜像**: 使用Docker命令从Docker Hub拉取Zabbix官方镜像,例如`zabbix/zabbix-server`。你可以使用以下命令: ``` docker pull zabbix/zabbix-server ``` 2. **运行Zabbix服务器容器**: 运行容器时,需要指定一些环境变量和端口映射。例如,你可以设置数据库连接信息,以及将Zabbix Web界面监听的端口映射到主机的8080端口: ``` docker run --name some-zabbix-server \ -e ZABBIX_SERVER_CONFIG_FILE=/etc/zabbix/zabbix_server.conf \ -e ZABBIX_DATABASE_HOST=your_database_host \ -e ZABBIX_DATABASE_USER=zabbix \ -e ZABBIX_DATABASE_PASSWORD=zabbix_password \ -p 8080:80 \ -d zabbix/zabbix-server ``` 其中,`some-zabbix-server`是容器名称,可以根据需要自定义。 3. **配置Zabbix Server**: 容器启动后,Zabbix可能还需要一些额外配置。你需要访问Zabbix Web界面(默认是http://localhost:8080),登录(默认admin/admin),然后根据需求设置网络监控、服务器组、模板等。 4. **安装MySQL或其他数据库(可选)**: 如果Zabbix需要数据库支持,你还需要运行一个数据库容器,如MySQL。确保容器间的数据共享和通信已经设置好。 5. **数据持久化**: 如果你希望数据持久化,可以使用挂载卷(-v参数)来保存配置文件和数据库数据: ``` -v /path/on/host/config:/etc/zabbix -v /path/on/host/data:/var/lib/zabbix ``` 6. **更新和扩展**: 对于后续的升级或扩展,可以直接基于已有的Zabbix镜像创建新容器,或通过Dockerfile构建自己的Zabbix镜像。 相关问题: 1. Docker镜像中的Zabbix Server如何连接外部数据库? 2. 如何在Zabbix容器中配置Web界面的权限? 3. 数据库容器如何与Zabbix服务器容器进行数据交互?
评论 38
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

愿许浪尽天涯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值