1. 首页
  2. 技术知识

使用 Docker安装 Zabbix并配置自定义监控项的过程详解

目录

    一、Zabbix 简介

      1.监控功能2.Zabbix 工作原理3.Zabbix 组件4.Zabbix 进程

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

      1.安装 Zabbix2.开启自定义监控项3.编写 Nginx 自定义监控脚本

一、Zabbix 简介

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

1.监控功能

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

1)监控对象

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

2)主机性能指标监控

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


2.Zabbix 工作原理

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

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

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

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

3.Zabbix 组件

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


4.Zabbix 进程

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

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

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

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


1.安装 Zabbix

1)安装 Docker

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

复制代码 2)安装 Docker-Compose

  1. [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       
  2. [root@Zabbix ~]# chmod +x /usr/local/bin/docker-compose
  3. [root@Zabbix ~]# docker-compose –version

复制代码 3)安装 Agent

  1. [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
  2. [root@Zabbix ~]# egrep -v ‘^$|#’ zabbix_agentd.conf
  3. PidFile=/var/run/zabbix/zabbix_agentd.pid
  4. LogFile=/var/log/zabbix/zabbix_agentd.log
  5. LogFileSize=0
  6. Server=127.0.0.1
  7. ServerActive=127.0.0.1
  8. Hostname=Zabbix server
  9. Include=/etc/zabbix/zabbix_agentd.d/*.conf
  10. [root@Zabbix ~]# systemctl enable zabbix-agent –now

复制代码 4)安装 Zabbix

  1. [root@Zabbix ~]# mkdir -p /app/zabbix
  2. [root@Zabbix ~]# cd /app/zabbix/
  3. [root@Zabbix zabbix]# cat <<END > docker-compose.yml
  4. version: “3”
  5. services:
  6.   mysql-server:
  7.     image: mysql:5.7
  8.     ports:
  9.       – “3306:3306”
  10.     volumes:
  11.       – “/app/mysql:/var/lib/mysql”                                # 配置数据卷 (防止监控数据丢失)
  12.     environment:
  13.       MYSQL_ROOT_PASSWORD: 123123
  14.       TZ: Asia/Shanghai
  15.     command: –character-set-server=utf8 –collation-server=utf8_bin
  16.     restart: always
  17.   zabbix-server:
  18.     image: zabbix/zabbix-server-mysql:5.4.8-centos
  19.     environment:
  20.       DB_SERVER_HOST: 127.0.0.1
  21.       DB_SERVER_PORT: 3306
  22.       MYSQL_DATABASE: zabbix
  23.       MYSQL_USER: root
  24.       MYSQL_PASSWORD: 123123
  25.       TZ: Asia/Shanghai
  26.     depends_on:
  27.       – mysql-server
  28.     restart: always
  29.     network_mode: “host”                                                # 使用主机网络
  30.   zabbix-web:
  31.     image: zabbix/zabbix-web-nginx-mysql:5.4.8-centos
  32.     ports:
  33.       – “8000:8080”                                                                # Zabbix WebUI 映射端口
  34.     volumes:                                                                        # 当在 Web 界面配置成中文后,监控界面会出现乱码
  35.       – “./simkai.ttf:/usr/share/zabbix/assets/fonts/DejaVuSans.ttf”
  36.     environment:
  37.       DB_SERVER_HOST: mysql-server
  38.       DB_SERVER_PORT: 3306
  39.       MYSQL_DATABASE: zabbix
  40.       MYSQL_USER: root
  41.       MYSQL_PASSWORD: 123123
  42.       TZ: Asia/Shanghai
  43.       ZBX_SERVER_HOST: 192.168.1.1
  44.     depends_on:
  45.       – mysql-server
  46.       – zabbix-server
  47.     restart: always
  48. END
  49. [root@Zabbix zabbix]# docker-compose up -d
  50. [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.开启自定义监控项

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

复制代码
3.编写 Nginx 自定义监控脚本

  1. [root@Zabbix ~]# yum -y install nginx
  2. [root@Zabbix ~]# cat <<END > /etc/nginx/conf.d/status.conf
  3. server {
  4.     listen 80;
  5.     server_name 127.0.0.1;
  6.     location /status {
  7.         stub_status on;
  8.         allow 127.0.0.1;
  9.         allow 192.168.1.0/24;
  10.         deny all;
  11.     }
  12. }
  13. END

复制代码 1)编写自定义监控脚本

  1. [root@Zabbix ~]# mkdir /etc/zabbix/scripts
  2. [root@Zabbix ~]# vim /etc/zabbix/scripts/nginx_status.sh
  3. #!/bin/bash
  4. HOST=”127.0.0.1″
  5. PORT=”80″
  6. # 监控 Nginx 进程是否存在
  7. functiоn Ping {
  8.     /sbin/pidof nginx | wc -l
  9. }
  10. # 监控 Nginx 状态信息
  11. functiоn Active {
  12.     /usr/bin/curl “http://$HOST:$PORT/status” 2> /dev/null | grep “Active” | awk ‘{print $NF}’
  13. }
  14. functiоn Reading {
  15.     /usr/bin/curl “http://$HOST:$PORT/status” 2> /dev/null | grep “Reading” | awk ‘{print $2}’
  16. }
  17. functiоn Writing {
  18.     /usr/bin/curl “http://$HOST:$PORT/status” 2> /dev/null | grep “Writing” | awk ‘{print $4}’
  19. }
  20. functiоn Waiting {
  21.     /usr/bin/curl “http://$HOST:$PORT/status” 2> /dev/null | grep “Waiting” | awk ‘{print $6}’
  22. }
  23. functiоn Server {
  24.     /usr/bin/curl “http://$HOST:$PORT/status” 2> /dev/null | awk NR==3 | awk ‘{print $1}’
  25. }
  26. functiоn Accepts {
  27.     /usr/bin/curl “http://$HOST:$PORT/status” 2> /dev/null | awk NR==3 | awk ‘{print $2}’
  28. }
  29. functiоn Requests {
  30.     /usr/bin/curl “http://$HOST:$PORT/status” 2> /dev/null | awk NR==3 | awk ‘{print $3}’
  31. }
  32. # 执行 functiоn
  33. $1
  34. [root@Zabbix ~]# chmod +x /etc/zabbix/scripts/nginx_status.sh

复制代码 2)定义监控脚本

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

复制代码 3)验证

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

复制代码

创建模板

创建应用集

创建监控项

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

给我们的监控项创建图形

将 Nginx 模板加入到主机中

查看监控图

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

到此这篇关于使用 Docker 安装 Zabbix,并配置自定义监控项的文章就介绍到这了,更多相关Docker 安装 Zabbix配置自定义监控项内容请搜索共生网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持共生网络!

原创文章,作者:starterknow,如若转载,请注明出处:https://www.starterknow.com/108286.html

联系我们