文章目录
前言
如今监控系统作为保障企业 IT 基础设施稳定运行的重要工具,其重要性日益凸显。Zabbix,作为一款功能强大且 开源
的监控软件,不仅能够对网络和服务器状态进行全面监控,还通过灵活的 通知机制
,确保了问题能够及时被响应和处理。本文将带领大家深入了解 Zabbix 的安装、配置以及如何利用其强大的 自定义监控
功能,实现对各种服务和应用的监控,旨在帮助技术界的新老朋友们快速掌握 Zabbix 的使用和管理,提升对于 IT 系统的 监控能力
。
大家好,我是技术界的小萌新,今天要和大家分享一些干货。在阅读之前请先点赞👍,给我一点鼓励吧!这对我来说很重要 (*^▽^*)
Zabbix 介绍:
Zabbix 是一款开源的企业级 分布式监控
解决方案,它能够监控网络和各种服务器的状态,包括虚拟机、应用程序、服务、数据库、网站以及云服务等的健康和完整性 。Zabbix 通过灵活的 通知机制
,使用户能够为几乎所有事件配置基于电子邮件的警报,从而快速响应服务器问题 。它还提供基于存储的数据的报告和 数据可视化
功能,使其成为容量规划的理想选择 。
Zabbix 的 特点
如下:
- Zabbix 是一套高度集成的监控解决方案。
- 可以实现企业级的开源
分布式
监控。 - Zabbix 通过 C/S 模式采集监控数据。
- Zabbix 通过 B/S 模式实现
web 管理
。
Zabbix 的 组件
有:
- zabbix agent:指标采集器,在被监控主机上采集指标数据,并将采集到的数据发送给 zabbix server。
- zabbix server:负责接收 agent 发送的数据,统计数据、管理数据。
- zabbix database:用于存储所有 zabbix 的配置信息以及监控数据,可用 Mysql,PostgreSQL。
- zabbix web:管理员通过 web 界面管理、配置以及查看相关监控信息,可用 Nginx,Apache。
- zabbix-proxy:分布式监控,用来分担 zabbix server 的压力(不是必须)。
一、环境准备
我们将要进行 Zabbix 的部署实践,并介绍其内置的功能与自定义监控项如何实现,来体会并学习 Zabbix 的完善监控解决方案。其他配置如下:
操作系统 | 为 Rocky 8.5 |
---|---|
zabbix 版本 | 6.0 |
主机 | IP |
---|---|
zabbixserver | 192.168.88.5 |
web1 | 192.168.88.100 |
web2 | 192.168.88.200 |
1、安装前准备
监控服务器需要使用 Web 页面进行操作,且为 php 页面,所以需要部署 LNMP
环境。
为了方便学习部署,关闭服务端 / 客户端的防火墙、关闭 SELinux。
2、准备软件包仓库
- zabbix 官网下载地址:
https://www.zabbix.com/cn/download?zabbix=6.0&os_distribution=red_hat_enterprise_linux&os_version=8&components=server_frontend_agent&db=mysql&ws=nginx
- zabbix 中文手册:
https://www.zabbix.com/documentation/6.0/zh
- 配置软件包仓库:
rpm -Uvh https://repo.zabbix.com/zabbix/6.0/rhel/8/x86_64/zabbix-release-6.0-5.el8.noarch.rpm
# 自动配置zabbix的 RPM 软件仓库
dnf makecache
# 刷新仓库信息
二、部署 Zabbix-server
1、安装 server,agent,web 等
Zabbix 已 集成
了管理监控平台所需的所有软件包与相应配置文件,包括数据库、用户 web 操作所需的 nginx 与 php 等,如果在 生产环境
不能关闭防火墙与 SELinux,也有适配的软件包,可以根据中文手册自行配置。
# 安装服务组件,及数据库和中文汉化包
dnf -y install zabbix-server-mysql zabbix-web-mysql zabbix-nginx-conf zabbix-sql-scripts zabbix-selinux-policy zabbix-agent mysql-server glibc-langpack-zh
2、配置 Zabbix 数据库
1) 创建 Zabbix 数据库
[root@zabbixserver ~] systemctl enable mysqld --now
[root@zabbixserver ~] mysql
mysql> create database zabbix character set utf8mb4 collate utf8mb4_bin; # 创建并设置数据库专用字符集
mysql> create user zabbix@localhost identified by 'zabbix'; # 创建 zabbix 服务用户
mysql> grant all privileges on zabbix.* to zabbix@localhost; # 配置用户的 zabbix 数据库权限
mysql> set global log_bin_trust_function_creators = 1; # 打开函数生成器,在后续生成提高查询效率的触发性函数
mysql> quit;
# 登录验证 用户、密码、数据库 是否配置错误
[root@zabbixserver ~]# mysql -uzabbix -pzabbix -hlocalhost zabbix
2) 导入 sql 数据到 Zabbix 数据库
确认无误
后导入 zabbix 为我们准备的 sql 数据库文件
zcat 是 gzip 工具套件的一部分,可以查看 gzip 压缩内容,并输出到终端,我们把数据库信息通过 zcat 导入到数据库中
**`zcat /usr/share/zabbix-sql-scripts/mysql/server.sql.gz | mysql -uzabbix -pzabbix zabbix@
3、修改配置文件
1) 为 Zabbix_server 配置数据库
如果有数据库配置与上述不一致,需在此处填写自定义的配置。
[root@zabbixserver ~] vim /etc/zabbix/zabbix_server.conf
# 创建的数据库名称 授权用户 用户密码
105 DBName=zabbix
121 DBUser=zabbix
129 DBPassword=zabbix
2) 配置 Zabbix_agent 客户端
Zabbix_server 依靠 agent 采集并上传监控数据,所以即使 zabbix 主机已安装服务端,也仍需安装客户端监控此控制节点。
# 为客户端配置控制节点的主机名,这将显示在 web 管理页面
[root@zabbixserver ~] vim /etc/zabbix/zabbix_agentd.conf
182 Hostname=zabbixserver
3) 配置 Nginx 发布 Zabbix 的 Web 页面
[root@zabbixserver ~] vim /etc/nginx/conf.d/zabbix.conf
# 打开 2,3 行的注释即可开放 8080 端口发布 web 管理页面
1 server {
2 # listen 8080;
3 # server_name example.com;
4) 启动服务
# 以上配置完毕,设置服务开机自启
[root@zabbixserver ~] systemctl enable --now zabbix-server zabbix-agent nginx php-fpm
[root@zabbixserver ~]# ss -ntulp | grep :8080
tcp LISTEN 0 511 0.0.0.0:8080 0.0.0.0:* users:(("nginx",pid=15993,fd=6