Zabbix 是一款监控网络的众多参数以及服务器、虚拟机、应用程序、服务、数据库、网站、云等的健康和完整性的软件。Zabbix 使用灵活的通知机制,允许用户为几乎任何事件配置基于电子邮件的告警,以实现对服务器问题做出快速反应。Zabbix 基于存储的数据提供出色的报告和数据可视化功能。这使得 Zabbix 成为容量规划的理想选择
Zabbix 支持轮询和 trapping。所有 Zabbix 报告和统计数据以及配置参数都可以通过基于 Web 的前端访问。基于 Web 的前端确保可以从任何位置评估您的网络状态和服务器的健康状况。如果配置得当,不管对于拥有少量服务器的小型组织还是拥有大量服务器的大公司来讲,Zabbix 都可以在监控 IT 基础设施方面发挥重要作用
zabbix agent安装在被监控的主机上,zabbix agent负责定期收集客户端本地各项数据,并发送至 zabbix server 端,zabbix server 收到数据后,将数据存储到数据库中,用户基于 Zabbix WEB 可以看到数据在前端展现图像。当 zabbix 监控某个具体的项目, 该项目会设置一个触发器阈值,当被监控的指标超过该触发器设定的阈值,会进行一些必要的动作,动作包括:发送信息(邮件、微信、短信)、发送命令(shell 命令、reboot、restart、install 等)
zabbix 监控部署在系统中,包含常见的五个程序: zabbix_server、zabbix_agent、zabbix_proxy、zabbix_get、zabbix_sender等
Zabbix server 是整个 Zabbix 软件的核心程序。
Zabbix Server 负责执行数据的主动轮询和被动获取,计算触发器条件,向用户发送通知。它是 Zabbix Agent 和 Proxy 报告系统可用性和完整性数据的核心组件。Server 自身可以通过简单服务远程检查网络服务(如Web服务器和邮件服务器)。
Zabbix Server是所有配置、统计和操作数据的中央存储中心,也是Zabbix监控系统的告警中心。在监控的系统中出现任何异常,将被发出通知给管理员。
基本的 Zabbix Server 的功能分解成为三个不同的组件。他们是:Zabbix server、Web前端和数据库。
Zabbix 的所有配置信息都存储在 Server 和Web前端进行交互的数据库中。例如,当你通过Web前端(或者API)新增一个监控项时,它会被添加到数据库的监控项表里。然后,Zabbix server 以每分钟一次的频率查询监控项表中的有效项,接着将它存储在 Zabbix server 中的缓存里。这就是为什么 Zabbix 前端所做的任何更改需要花费两分钟左右才能显示在最新的数据段的原因。
Zabbix agent 部署在被监控目标上,以主动监控本地资源和应用程序(硬盘、内存、处理器统计信息等)。
Zabbix agent 收集本地的操作信息并将数据报告给 Zabbix server 用于进一步处理。一旦出现异常 (例如硬盘空间已满或者有崩溃的服务进程),Zabbix server 会主动警告管理员指定机器上的异常。
Zabbix agents 的极高效率缘于它可以利用本地系统调用来完成统计数据的采集。
收集方式
在被动检查模式中 agent 应答数据请求。Zabbix server(或 proxy)询求数据,例如 CPU load,然后 Zabbix agent 返还结果。
主动检查处理过程将相对复杂。Agent 必须首先从 Zabbix sever 索取监控项列表以进行独立处理,然后会定期发送采集到的新值给 Zabbix server。
是否执行被动或主动检查是通过选择相应的监控项类型来配置的。 Zabbix agent 处理“Zabbix agent”或“Zabbix agent(active)”类型的监控项。
Zabbix agent 2 为新一代zabbix agent,未来可能会替代原Zabbix agent。Zabbix agent 2可以实现:
Zabbix proxy 是一个可以从一个或多个受监控设备采集监控数据并将信息发送到 Zabbix server 的进程,主要是代表 Zabbix server 工作。 所有收集的数据都在本地缓存,然后传输到 proxy 所属的 Zabbix server。
部署Zabbix proxy 是可选的,但可能非常有利于分担单个 Zabbix server 的负载。 如果只有代理采集数据,则 Zabbix server 上会减少 CPU 和磁盘 I/O 的开销。
Zabbix proxy 是无需本地管理员即可集中监控远程位置、分支机构和网络的理想解决方案。
Zabbix proxy 需要使用独立的数据库。
从 Zabbix 2.0 开始,以 Zabbix 守护进程方式原生支持监控 JMX 应用程序就存在了,称之为“Zabbix Java gateway”。Zabbix Java gateway 的守护进程是用 Java 编写。为了在特定主机上找到 JMX 计数器的值,Zabbix server 向 Zabbix Java gateway 发送请求,后者使用 JMX 管理 API来远程查询相关的应用。该应用不需要安装额外的软件。只需要在启动时,命令行添加-Dcom.sun.management.jmxremote
选项即可。
Zabbix sender 是一个命令行应用程序,可用于将性能数据发送到 Zabbix server 进行处理。
该实用程序通常用于长时间运行的用户脚本,用于定期发送可用性和性能数据。
要将结果直接发送到 Zabbix server 或 proxy,必须配置 trapper 监控项 类型。
Zabbix get 是一个命令行应用,它可以用于与 Zabbix agent 进行通信,并从 Zabbix agent 那里获取所需的信息。
该应用通常被用于 Zabbix agent 故障排错。
zabbix_js 是一个命令行实用程序,可用于嵌入脚本测试。
该程序可执行带有字符串参数的用户自定义脚本并打印结果。脚本的执行是由内嵌的Zabbix脚本引擎来完成的。
在编译或执行错误的情况下,zabbix_js将在stderr中打印错误并以代码1退出。
Zabbix服务端:192.168.237.128
[root@localhost ~]# systemctl disable --now firewalld #永久关闭防火墙
Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
[root@localhost ~]# setenforce 0 #关闭Selinux
[root@localhost ~]# hostnamectl set-hostname zbx-server #更改主机名
[root@localhost ~]# su #切换
[root@zbx-server ~]# rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm #下载安装zabbix
获取https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm
警告:/var/tmp/rpm-tmp.XBPBux: 头V4 RSA/SHA512 Signature, 密钥 ID a14fe591: NOKEY
准备中... ################################# [100%]
正在升级/安装...
1:zabbix-release-5.0-1.el7 ################################# [100%]
[root@zbx-server ~]# cd /etc/yum.repos.d
[root@zbx-server yum.repos.d]# sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' zabbix.repo #更换zabbix为阿里源
[root@zbx-server yum.repos.d]# yum clean all && yum makecache #清空yum缓存,重新建立
[root@zbx-server yum.repos.d]# yum install -y zabbix-server-mysql zabbix-agent #安装zabbix-server-mysql和zabbix-agent
[root@zbx-server yum.repos.d]# yum install -y centos-release-scl #安装SCL(Software Collections),便于后续安装高版本的 php,默认 yum 安装的 php 版本为 5.4,版本过低,zabbix 5.0 版本对 php 版本最低要 7.2.0 版本。SCL 可以使得在同一台机器上使用多个版本的软件,而又不会影响整个系统的依赖环境。软件包会安装在 /etc/opt/rh目录下
[root@zbx-server yum.repos.d]# vim zabbix.repo
......
[zabbix-frontend]
......
enabled=1 #开启安装源
......
:wq
[root@zbx-server yum.repos.d]# yum install -y zabbix-web-mysql-scl zabbix-apache-conf-scl #安装zabbix-web-mysql-scl zabbix-apache-conf-scl
[root@zbx-server yum.repos.d]# yum install -y mariadb-server mariadb #安装支持的数据库
[root@zbx-server yum.repos.d]# systemctl enable --now mariadb #加入开机自启
Created symlink from /etc/systemd/system/multi-user.target.wants/mariadb.service to /usr/lib/systemd/system/mariadb.service.
[root@zbx-server yum.repos.d]# mysql_secure_installation #初始化数据库,并设置密码,如 abc123
[root@zbx-server yum.repos.d]# mysql -u root -pabc123 #登录数据库
Welcome to the MariaDB monitor. Commands end with ; or \g.
Your MariaDB connection id is 12
Server version: 5.5.68-MariaDB MariaDB Server
Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
MariaDB [(none)]> CREATE DATABASE zabbix character set utf8 collate utf8_bin; #创建zabbix的库
Query OK, 1 row affected (0.00 sec)
MariaDB [(none)]> GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix'; #赋予权限
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> flush privileges; #刷新权限
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> quit #退出
Bye
[root@zbx-server yum.repos.d]# rpm -ql zabbix-server-mysql #查询sql文件的位置
/etc/logrotate.d/zabbix-server
/etc/zabbix/zabbix_server.conf
/usr/lib/systemd/system/zabbix-server.service
/usr/lib/tmpfiles.d/zabbix-server.conf
/usr/lib/zabbix/alertscripts
/usr/lib/zabbix/externalscripts
/usr/sbin/zabbix_server_mysql
/usr/share/doc/zabbix-server-mysql-5.0.25
/usr/share/doc/zabbix-server-mysql-5.0.25/AUTHORS
/usr/share/doc/zabbix-server-mysql-5.0.25/COPYING
/usr/share/doc/zabbix-server-mysql-5.0.25/ChangeLog
/usr/share/doc/zabbix-server-mysql-5.0.25/NEWS
/usr/share/doc/zabbix-server-mysql-5.0.25/README
/usr/share/doc/zabbix-server-mysql-5.0.25/create.sql.gz
/usr/share/doc/zabbix-server-mysql-5.0.25/double.sql
/usr/share/man/man8/zabbix_server.8.gz
/var/log/zabbix
/var/run/zabbix
[root@zbx-server yum.repos.d]# zcat /usr/share/doc/zabbix-server-mysql-5.0.25/create.sql.gz | mysql -uroot -pabc123 zabbix #导入MySQL表
[root@zbx-server yum.repos.d]# vim /etc/zabbix/zabbix_server.conf
......
DBPassword=zabbix #124行,指定 zabbix 数据库的密码
[root@zbx-server yum.repos.d]# vim /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf
......
php_value[date.timezone] = Asia/Shanghai #25行,取消注释,修改时区
#启动zabbix相关服务
[root@zbx-server yum.repos.d]# systemctl restart zabbix-server zabbix-agent httpd rh-php72-php-fpm
[root@zbx-server yum.repos.d]# systemctl enable zabbix-server zabbix-agent httpd rh-php72-php-fpm
Created symlink from /etc/systemd/system/multi-user.target.wants/zabbix-server.service to /usr/lib/systemd/system/zabbix-server.service.
Created symlink from /etc/systemd/system/multi-user.target.wants/zabbix-agent.service to /usr/lib/systemd/system/zabbix-agent.service.
Created symlink from /etc/systemd/system/multi-user.target.wants/httpd.service to /usr/lib/systemd/system/httpd.service.
Created symlink from /etc/systemd/system/multi-user.target.wants/rh-php72-php-fpm.service to /usr/lib/systemd/system/rh-php72-php-fpm.service.
浏览器访问:http://192.168.237.128/zabbix
点击next step->next step->,设置数据库的密码zabbix,点击next step,不设置name继续next step->next step->finish
安装完成后,默认的登录账号和密码为:Admin/zabbix
设置文件界面:点击左边菜单栏的【User settings】,【Language】选择 Chinese(zh_CN),再点击 Update 更新
Zabbix客户端:192.168.237.138
zabbix 5.0 版本采用 golang 语言开发的新版本客户端 agent2
zabbix服务端zabbix_server默认使用10051端口,客户端zabbix_agent2默认使用10050端口
[root@localhost ~]# systemctl disable --now firewalld #永久关闭防火墙
Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
[root@localhost ~]# setenforce 0 #关闭Selinux
[root@localhost ~]# hostnamectl set-hostname zbx-agent01
[root@localhost ~]# su #切换
#服务端和客户端都配置时间同步
[root@zbx-agent01 ~]# yum install -y ntpdate
[root@zbx-agent01 ~]# ntpdate -u ntp.aliyun.com
4 Jul 20:04:20 ntpdate[17512]: adjust time server 203.107.6.88 offset -0.024466 sec
[root@zbx-agent01 ~]# mv /etc/localtime{,.bak} #备份
[root@zbx-agent01 ~]# ln -s /usr/share/zoneinfo/Asia/Shanghai /etc/localtime #创建软链接
[root@zbx-agent01 ~]# date
2022年 07月 04日 星期一 20:05:06 CST #验证日期
[root@zbx-agent01 ~]# rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm #设置zabbix的下载源,安装 zabbix-agent2
获取https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm
警告:/var/tmp/rpm-tmp.BnSLbP: 头V4 RSA/SHA512 Signature, 密钥 ID a14fe591: NOKEY
准备中... ################################# [100%]
正在升级/安装...
1:zabbix-release-5.0-1.el7 ################################# [100%]
[root@zbx-agent01 ~]# cd /etc/yum.repos.d
[root@zbx-agent01 yum.repos.d]# sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' /etc/yum.repos.d/zabbix.repo #更换zabbix为阿里源
[root@zbx-agent01 yum.repos.d]# yum install -y zabbix-agent2 #安装zabbix-agent2
[root@zbx-agent01 yum.repos.d]# vim /etc/zabbix/zabbix_agent2.conf
......
Server=192.168.237.128 #80行,指定zabbix服务端的IP地址
ServerActive=192.168.237.128 #120行,指定zabbix服务端的IP地址
Hostname=zbx-agent01 #131行,指定当前zabbix客户端的主机名
:wq
[root@zbx-agent01 yum.repos.d]# systemctl start zabbix-agent2
[root@zbx-agent01 yum.repos.d]# systemctl enable zabbix-agent2
Created symlink from /etc/systemd/system/multi-user.target.wants/zabbix-agent2.service to /usr/lib/systemd/system/zabbix-agent2.service.
[root@zbx-agent01 yum.repos.d]# netstat -natp | grep zabbix
tcp6 0 0 :::10050 :::* LISTEN 17633/zabbix_agent2
服务端验证
[root@zbx-agent01 yum.repos.d]# yum install -y zabbix-get #安装zabbix主动获取数据的命令
#验证连通性
[root@zbx-server yum.repos.d]# zabbix_get -s '192.168.237.148' -p 10050 -k 'agent.ping'
1
[root@zbx-server yum.repos.d]# zabbix_get -s '192.168.237.148' -p 10050 -k 'system.hostname'
zbx-agent01
点击左边菜单栏【配置】中的【主机】,点击【创建主机】
【主机名称】设置成 zbx-agent01
【可见的名称】设置成 zbx-agent01-192.168.237.148
【群组】选择 Linux server
【Interfaces】的【IP地址】设置成 192.168.237.148
再点击上方菜单栏【模板】
【Link new tamplates】搜索 Linux ,选择 Template OS Linux by Zabbix agent
点击 【添加】
案列:自定义监控客户端服务器登录的人数
需求:限制登录人数不超过3个,超过3个就发出报警信息
#在客户端创建自定义 key
明确需要执行的 linux 命令
[root@zbx-agent01 yum.repos.d]# who | wc -l #查看当前登陆人数
3
创建 zabbix 的监控项配置文件,用于自定义key
vim /etc/zabbix/zabbix_agent2.conf #修改配置文件,可以将自定义的监控项配置文件创建在zabbix_agent2.d目录中
Include=/etc/zabbix/zabbix_agent2.d/*.conf #268行,自定义监控项配置文件的储存储存目录
#Format: UserParameter=, #这一行一定不要取消注释
:wq
[root@zbx-agent01 yum.repos.d]# cd /etc/zabbix/zabbix_agent2.d/
[root@zbx-agent01 zabbix_agent2.d]# vim UserParameter_login.conf
vim UserParameter_login.conf
UserParameter=login.user,who|wc -l
:wq
[root@zbx-agent01 zabbix_agent2.d]# systemctl restart zabbix-agent2
3.在服务端验证新建的监控项
[root@zbx-server yum.repos.d]# zabbix_get -s '192.168.237.148' -p 10050 -k 'login.user'
3
1.创建模板
点击左边菜单栏【配置】中的【模板】,点击【创建模板】
【模板名称】设置成 Template Login User
【可见的名称】设置成 Template Login User
【群组】选择 Templates
【描述】可自定义
点击 【添加】,此时就可在【链接的模板】中搜索到Template Login User了
2.创建应用集(用于管理监控项的)
模板-名称搜索Template Login User
点击【应用集】,点击【创建应用集】
【名称】设置成Login User
点击 【添加】
3.创建监控项
点击上方菜单栏【监控项】,点击【创建监控项】
【名称】设置成 Number of login users
【键值】设置成 login.user #键值必须要与自定义的监控项配置文件中设置的保持一致
【更新间隔】设置成 15s
【历史数据保留时长】Storage period 30d #保留时间可自定义设置
点击 【添加】
4.创建触发器(当监控项获取到监控的值后和触发器预设的值进行对比,判断是否报警)
点击上方菜单栏【触发器】,点击【创建触发器】
【名称】设置成 Number of login users is greater than 3
【严重性】设置成 一般严重
【表达式】点击添加,【监控项】点击选择 Number of login users,【功能】选择 last(),【结果】选择 > 3,点击 【插入】
点击 【添加】
5.创建图形
点击上方菜单栏【图形】,点击【创建图形】
【名称】设置成 Number of login users
【宽】、【高】可直接采用默认值
【监控项】点击添加勾选相关监控项 Number of login users,【功能】选择 最大,其它可保持默认值
点击 【添加】
6.将主机与模板关联起来(一个主机可以关联多个模板)
点击左边菜单栏【配置】中的【主机】,点击你要关联的主机
点击上方菜单栏【模板】,【Link new tamplates】搜索 login,选择 Template Login User,点击【更新】
此时就点击【监测】中的【主机】,点击你关联主机的【图形】,即可查看到相关的监控项指标
7.设置邮件报警
点击左边菜单栏【管理】中的【报警媒介类型】,点击【创建媒体类型】
【名称】设置成 qq_Email
【SMTP服务器】设置成 smtp.qq.com
【SMTP服务器端口】设置成 25
【SMTP HELO】设置成 qq.com
【SMTP电邮】设置成自己的邮箱地址。
【认证】选择 用户名和密码
【用户名称】设置成自己的邮箱地址。
【密码】可登录QQ邮箱页面,点击【设置】-->【账户】,POP3/IMAP/SMTP/Exchange/CardDAV/CalDAV服务,开启POP3/SMTP服务 (如何使用 Foxmail 等软件收发邮件?),通过短信获取授权码,将授权码复制到密码中
【描述】可自定义
点击上方菜单栏【Message templates】,点击【添加】,【Message type】选择问题->然后点击添加
点击左边菜单栏【User settings】-->【报警媒介】,点击【添加】
【类型】选择 qq_Email
【收件人】设置成自己邮箱
【当启用时】设置成 1-7,00:00-24:00
点击 【添加】
再点击 【更新】
点击左边菜单栏【配置】中的【动作】
选择相对应的动作名称点击进入,点击 【添加】
【类型】选择 触发器,【触发器】点击选择 Nunber of login users is greater than 3
勾选【已启用】
测试邮件报警
增加测试客户端的用户登录数超过触发器预设的值,查看【监测】-->【仪表盘】,确认报警
#zabbix自动发现(对于 agent2 是被动模式)
zabbix server 主动的去发现所有的客户端,然后将客户端的信息登记在服务端上。
缺点是如果定义的网段中的主机数量多,zabbix server 登记耗时较久,且压力会较大。
1.确保客户端上的 zabbix-agent2 服务状态正常
[root@zbx-agent01 ~]# systemctl is-active zabbix-agent2.service
active
2.在 Web 页面删除原有的客户端主机
点击左边菜单栏【配置】中的【主机】,勾选原有的客户端主机,点击删除
3.在服务端和客户端上配置 hosts 解析
[root@zbx-server ~]# vim /etc/hosts
192.168.237.148 zbx-agent01
192.168.237.128 zbx-server
:wq
[root@zbx-agent01 ~]# vim /etc/hosts
192.168.237.148 zbx-agent01
192.168.237.128 zbx-server
:wq
4.在 Web 页面配置自动发现
点击左边菜单栏【配置】中的【自动发现】,点击【创建发现规则】
【名称】设置成 mynetwork
【IP范围】设置成 192.168.237.1-254
【更新间隔】设置成 30s
【检查】点击【添加】,【检查类型】选择 Zabbix 客户端,【端口范围】设置成 10050,【键值】设置成 system.uname
【设备唯一性准则】选择 IP地址
【主机名称】选择 DNS名称
【可见的名称】选择 主机名称
勾选 【已启用】,点击 【更新】
点击左边菜单栏【配置】中的【动作】,上方菜单选择 【Discovery actions】
勾选 【Auto discovery. Linux servers.】,选择【启用】,更新
点击左边菜单栏【配置】中的【主机】刷新,等待一段时间后即可刷新出自动发现的客户端主机
可在服务端查看 zabbix 日志
[root@zbx-server ~]# tail -f /var/log/zabbix/zabbix_server.log
......
13470:20220704:235324.565 enabling Zabbix agent checks on host "zbx-agent01": host became available
------------------------------------------------------------------------------------------------------------
#zabbix 自动注册(对于 agent2 是主动模式)
zabbix agent2 会主动上报自己的信息,发给 zabbix server。
缺点是可能因为配置文件配置错误或者网络不通等原因导致 zabbix agent2 可能找不到 zabbix server。
1.环境准备
点击左边菜单栏【配置】中的【自动发现】,勾选发现规则,点击 禁用
点击左边菜单栏【配置】中的【主机】,勾选原有的客户端主机,点击 删除
[root@zbx-server ~]# vim /etc/hosts
192.168.237.128 zbx-server
192.168.237.148 zbx-agent01
:wq
[root@zbx-agent01 ~]# vim /etc/hosts
192.168.237.128 zbx-server
192.168.237.148 zbx-agent01
:wq
2.修改 zabbix-agent2 配置文件
[root@zbx-agent01 ~]# vim /etc/zabbix/zabbix_agent2.conf
......
HostnameItem=system.hostname #139行,取消注释
:wq
[root@zbx-agent01 ~]# egrep -v "^#|^$" /etc/zabbix/zabbix_agent2.conf #过滤配置项
PidFile=/var/run/zabbix/zabbix_agent2.pid
LogFile=/var/log/zabbix/zabbix_agent2.log
LogFileSize=0
Server=192.168.237.128
ServerActive=192.168.237.128
Hostname=zbx-agent01
HostnameItem=system.hostname
Include=/etc/zabbix/zabbix_agent2.d/*.conf
ControlSocket=/tmp/agent.sock
:wq
3.在 Web 页面配置自动注册
点击左边菜单栏【配置】中的【动作】,上方菜单选择 【Autoregistration actions】,点击【创建动作】
【名称】设置成 Auto registration
点击 【添加】,【类型】选择 主机名称,【操作者】选择 包含,【值】设置成 zbx-agent01
点击上方菜单栏【操作】,点击【添加】,【操作类型】选择 添加主机,点击 【add】
再点击【添加】,【操作类型】选择 添加到主机群组,【主机群组】选择 Linux servers,点击 【add】
再点击【添加】,【操作类型】选择 与模板关联,【模板】搜索 Linux,选择 Template OS Linux by Zabbix agent,点击 【add】
点击下方的【添加】
点击左边菜单栏【配置】中的【主机】刷新,等待一段时间后即可刷新出自动发现的客户端主机
在服务端查看 zabbix 日志
[root@zbx-server ~]# tail -f /var/log/zabbix/zabbix_server.log
.........
13471:20220704:234723.724 enabling Zabbix agent checks on host "zbx-agent01": host became available
分布式监控的作用
代理服务器:192.168.237.138
agent --> proxy --> server
[root@192 ~]# systemctl disable --now firewalld
Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
[root@192 ~]# setenforce 0
[root@192 ~]# hostnamectl set-hostname zbx-proxy
[root@192 ~]# su
[root@zbx-proxy ~]# rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm #设置zabbix的下载源,安装zabbix-proxy
获取https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm
警告:/var/tmp/rpm-tmp.BY7rsr: 头V4 RSA/SHA512 Signature, 密钥 ID a14fe591: NOKEY
准备中... ################################# [100%]
正在升级/安装...
1:zabbix-release-5.0-1.el7 ################################# [100%]
[root@zbx-proxy ~]# cd /etc/yum.repos.d
[root@zbx-proxy yum.repos.d]# sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' /etc/yum.repos.d/zabbix.repo #s谁知zabbix的repo
[root@zbx-proxy yum.repos.d]# yum install -y zabbix-proxy-mysql zabbix-get #安装zabbix-proxy的组件
[root@zbx-proxy yum.repos.d]# yum install -y mariadb-server mariadb #安装 zabbix 所需的数据库
[root@zbx-proxy yum.repos.d]# systemctl enable --now mariadb #加入自启动,并启动
Created symlink from /etc/systemd/system/multi-user.target.wants/mariadb.service to /usr/lib/systemd/system/mariadb.service.
[root@zbx-proxy yum.repos.d]# mysql_secure_installation #初始化数据库,并设置密码,如 abc123
#添加数据库用户,以及 zabbix 所需的数据库信息
[root@zbx-proxy yum.repos.d]# mysql -u root -pabc123
Welcome to the MariaDB monitor. Commands end with ; or \g.
Your MariaDB connection id is 10
Server version: 5.5.68-MariaDB MariaDB Server
Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
MariaDB [(none)]> CREATE DATABASE zabbix_proxy character set utf8 collate utf8_bin;
Query OK, 1 row affected (0.00 sec)
MariaDB [(none)]> GRANT all ON zabbix_proxy.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> flush privileges;
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> quit
Bye
#导入数据库信息
[root@zbx-proxy yum.repos.d]# rpm -ql zabbix-proxy-mysql #查询 sql 文件的位置
/etc/logrotate.d/zabbix-proxy
/etc/zabbix/zabbix_proxy.conf
/usr/lib/systemd/system/zabbix-proxy.service
/usr/lib/tmpfiles.d/zabbix-proxy.conf
/usr/lib/zabbix/externalscripts
/usr/sbin/zabbix_proxy_mysql
/usr/share/doc/zabbix-proxy-mysql-5.0.25
/usr/share/doc/zabbix-proxy-mysql-5.0.25/AUTHORS
/usr/share/doc/zabbix-proxy-mysql-5.0.25/COPYING
/usr/share/doc/zabbix-proxy-mysql-5.0.25/ChangeLog
/usr/share/doc/zabbix-proxy-mysql-5.0.25/NEWS
/usr/share/doc/zabbix-proxy-mysql-5.0.25/README
/usr/share/doc/zabbix-proxy-mysql-5.0.25/schema.sql.gz
/usr/share/man/man8/zabbix_proxy.8.gz
/var/log/zabbix
/var/run/zabbix
[root@zbx-proxy yum.repos.d]# zcat /usr/share/doc/zabbix-proxy-mysql-5.0.25/schema.sql.gz | mysql -uroot -pabc123 zabbix_proxy #导入数据库信息
[root@zbx-proxy yum.repos.d]# vim /etc/zabbix/zabbix_proxy.conf #修改zabbix-proxy配置文件
Server=192.168.237.128 #30行,指定 zabbix 服务端的 IP 地址
Hostname=zbx-proxy #49行,指定当前 zabbix 代理服务器的主机名
DBPassword=zabbix #196行,指定当前数据库 zabbix 用户的密码
:wq
[root@zbx-proxy yum.repos.d]# systemctl start zabbix-proxy #启动zabbix-proxy
[root@zbx-proxy yum.repos.d]# systemctl enable zabbix-proxy #开机自启
Created symlink from /etc/systemd/system/multi-user.target.wants/zabbix-proxy.service to /usr/lib/systemd/system/zabbix-proxy.service.
//在所有主机上配置 hosts 解析
[root@zbx-proxy yum.repos.d]# vim /etc/hosts
192.168.237.128 zbx-server
192.168.237.148 zbx-agent01
192.168.237.138 zbx-proxy
在Web页面配置agent代理
点击左边菜单栏【配置】中的【动作】,勾选自动注册规则,点击禁用
点击左边菜单栏【配置】中的【主机】,勾选原有的客户端主机,点击删除
点击左边菜单栏【管理】中的【agent代理程序】,点击【创建代理】
【agent代理程序名称】设置为 zbx-proxy
【系统代理程序模式】选择主动式
【代理地址】设置为 192.168.237.138
点击 【添加】
配置agent使用proxy
1.在客户端修改agent2配置文件
[root@zbx-agent01 ~]# vim /etc/zabbix/zabbix_agent2.conf
......
Server=192.168.237.138 #80行,指定zabbix代理服务器的IP地址
ServerActive=192.168.237.138 #120行,指定zabbix代理服务器的IP地址
2.在 Web 页面配置
点击左边菜单栏【配置】中的【主机】,点击【创建主机】
【主机名称】设置成 zbx-agent01
【可见的名称】设置成 zbx-agent01
【群组】选择 Linux servers
【Interfaces】的【IP地址】设置成 192.168.237.148
【由agent代理程序监测】选择 zbx-proxy
再点击上方菜单栏【模板】
【Link new tamplates】搜索 Linux ,选择 Template OS Linux by Zabbix agent
点击 【添加】
3.分别在客户端和代理服务器上重启服务
[root@zbx-agent01 ~]# systemctl restart zabbix-agent2
[root@zbx-proxy yum.repos.d]# systemctl restart zabbix-proxy
点击左边菜单栏【配置】中的【主机】刷新,查看客户端主机监控状态正常
在服务端查看日志
[root@zbx-proxy yum.repos.d]# tail -f /var/log/zabbix/zabbix_proxy.log
52371:20220705:004618.827 enabling Zabbix agent checks on host "zbx-agent01": host became available
1.服务端安装 snmp 监控程序
[root@zbx-server zabbix]# yum install -y net-snmp net-snmp-utils
2.修改 snmp 的配置文件,并启动服务
[root@zbx-server zabbix]# vim /etc/snmp/snmpd.conf
......
view systemview included .1 #57行,添加此配置
:wq
[root@zbx-server zabbix]# systemctl start snmpd
3.使用 snmp 命令测试
[root@zbx-server zabbix]# snmpwalk -v 2c -c public 127.0.0.1 sysname
SNMPv2-MIB::sysName.0 = STRING: zbx-server
-------------------------------------------------------
–v 1|2c|3:指定SNMP协议版本
–c:指定共同体字符串
sysname:为 snmp 的 key
-------------------------------------------------------
4.在 Web 页面配置 snmp 方式监控
点击左边菜单栏【配置】中的【主机】,点击 Zabbix server
【Interfaces】点击【添加】选择 SNMP ,端口设置成 161
点击上方菜单栏【模板】,【链接的模板】中的所有 agent 模板选择取消链接并清理
再在【Link new templates】中搜索 Linux SNMP,选择 Template OS Linux SNMP
点击 【更新】,等待一段时间后 Zabbix server 的可用性就变成了 SNMP 监控方式。
总结:难度不大,配置不改错即可。