当前位置:首页 > 编程技术 > 正文内容

【说站】在Docker上安装Zabbix并配置自定义监控项

yc8882年前 (2022-07-26)编程技术198

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 组件

在Docker上安装Zabbix并配置自定义监控项

4.Zabbix 进程

  • Sender:用于发送数据给 Server 或者 Proxy,通常用于耗时比较长的检查;

  • Get:Zabbix 命令,主要用于排查使用,可以在监控端上执行,来获取被监控端的信息;

  • Agent:客户端守护进程,用于收集当前主机的数据信息,如:CPU 负载、内存的使用情况等;

  • Proxy:代理守护进程,相当于是一个中转站,可以将收集到的数据信息 主动/被动 的提交到监控端上;

  • 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.pidLogFile=/var/log/zabbix/zabbix_agentd.logLogFileSize=0Server=127.0.0.1ServerActive=127.0.0.1Hostname=Zabbix serverInclude=/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.ymlversion: "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: alwaysEND[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)


在Docker上安装Zabbix并配置自定义监控项

界面上出现:zabbix server is not running: the information displayed may not be current 报错;


原因可能是因为我们 docker-compose 文件中的 ZBX_SERVER_HOST 变量配置的值不是 Zabbix Server 的 IP 地址导致的。

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

配置中文


在Docker上安装Zabbix并配置自定义监控项

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.confserver {    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/bashHOST="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.confUserParameter=nginx.status[*],/etc/zabbix/scripts/nginx_status.sh $1END[root@Zabbix ~]# systemctl restart zabbix-agent

3)验证

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


在Docker上安装Zabbix并配置自定义监控项

创建模板



在Docker上安装Zabbix并配置自定义监控项

创建应用集



在Docker上安装Zabbix并配置自定义监控项

创建监控项



在Docker上安装Zabbix并配置自定义监控项

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



在Docker上安装Zabbix并配置自定义监控项

给我们的监控项创建图形



在Docker上安装Zabbix并配置自定义监控项

将 Nginx 模板加入到主机中



在Docker上安装Zabbix并配置自定义监控项

查看监控图



在Docker上安装Zabbix并配置自定义监控项

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


本站发布的内容若侵犯到您的权益,请邮件联系站长删除,我们将及时处理!


从您进入本站开始,已表示您已同意接受本站【免责声明】中的一切条款!


本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行研究。


本站资源仅供学习和交流使用,版权归原作者所有,请勿商业运营、违法使用和传播!请在下载后24小时之内自觉删除。


若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。


本文链接:https://www.10zhan.com/biancheng/7444.html

分享给朋友:

“【说站】在Docker上安装Zabbix并配置自定义监控项” 的相关文章

【说站】laravel实现自定义404页面并给页面传值

【说站】laravel实现自定义404页面并给页面传值

以 laravel5.8 为例,虽然有自带的404页面,但太简单,我们更希望能自定义404页面,将用户留在站点。实现的方式很简单,将自定义的视图文件命名为 404.blade.php,并放到 reso...

【说站】Thymeleaf报错Error resolving template “XXX”

【说站】Thymeleaf报错Error resolving template “XXX”

修改了一下开源项目的目录结构访问突然报错Error resolving template “XXX”可能原因有如下三种:第一种可能:原因:在使用springboot的过程中,如果使用thymeleaf...

【说站】用一句话就可以去除宝塔面板操作上的二次验证

【说站】用一句话就可以去除宝塔面板操作上的二次验证

用过宝塔的朋友应该都会发现,现在宝塔面板有些鸡肋的功能,删除文件、删除数据库、删除站点等操作都需要做计算题!不仅加了几秒的延时等待,还无法跳过!这时候就会有朋友在想,如何去除宝塔面板的二次验证,此篇文...

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

这篇文章主要介绍了详解Centos8 配置静态IP的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来学习一下!1. 查看自己的网关地址点击虚...

【说站】利用Webhook实现Java项目自动化部署

【说站】利用Webhook实现Java项目自动化部署

用webhook就能实现Java项目自动部署,其实原理很简单。费话不多说,直接往下看教程。1. 创建gitee仓库并初始化2. 在linux安装git3. 在宝塔的软件的商店里下载Webhook4....

【说站】电脑安装MySQL时出现starting the server失败原因及解决方案

【说站】电脑安装MySQL时出现starting the server失败原因及解决方案

今天在安装MySQL时出现starting the server失败,经过查询分析得出以下结论,记录一下操作步骤。原因分析:如果电脑是第一次安装MySQL,一般不会出现这样的报错。如下图所示。star...