前言
作为一名运维人员,我们需要学会使用监控系统来查看服务器状态以及网站流量指标,利用监控系统的数据来了解上线发布的结果,和网站的健康状态。
利用一个优秀的监控软件,我们可以:
通过一环友好的界面进行浏览整个网站所有的服务器状态
可以在Web 前端方便的查看监控数据
可以回溯寻找事故发生时系统的问题和报警情况
今天,向大家介绍一款企业级的、开源的网络监控系统解决方案------zabbix
一、zabbix介绍
1.1 zabbix是什么
zabbix是一个基于Web界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。
zabbix能监视各种网络参数,保证服务器系统的安全运营;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。
zabbix由2部分构成,zabbix server与可选组件zabbix agent。通过C/S模式采集数据,通过B/S模式在Web端展示和配置。
zabbix server 可以通过SNMP,zabbix agent,ping,端口监视等方法提供对远程服务器/网络状态的监视,数据收集等功能,它可以运行在Linux等平台上。
zabbix agent 需要安装在被监视的目标服务器上,它主要完成对硬件信息或与操作系统有关的内存,CPU等信息的收集。
1.2 zabbix运行原理分析
zabbix agent 安装在被监控的主机上,zabbix agent 负责定期收集客户端本地各项数据,并发送至 zabbix server 端,zabbix server 收到数据后,将数据存储到数据库中,用户基于 zabbix WEB 可以看到数据在前端展现图像。当zabbix监控某个具体的项目,该项目会设置一个触发器阈值,当被监控的指标超过该触发器设定的阅值,会进行一些必要的动作,动作包括:发送信息(邮件、微信、短信)、发送命令(shell命令、reboot、restart、install等)。
1.3 zabbix常见的五个程序
zabbix server:zabbix 服务端守护进程,其中zabbix_agent、zabbix_get、zabbix_sender、zabbix_proxy的数据最都提交给zabbix server;
zabbix agent:客户端守护进程,负责收集客户端数据,例如:收集CPU负载、内存、硬盘使用情况等;
zabbix proxy:zabbix分布式代理守护进程,通常大于500台主机,需要进行分布式监控架构部署;
zabbix get:zabbix数据接收工具,单独使用的命令,通常在server或者proxy 端执行获取远程客户端信息的命令;
zabbix sender:zabbix 数据发送工具,用户发送数据给server或proxy端,通常用户耗时比较长的检查。
二、Zabbix部署安装
2.1 初始环境
节点 | IP | ||
---|---|---|---|
|
|||
|
|||
systemctl stop firewalld && setenforce 0
2.2 Zabbix-Server
zabbix-server 内存至少 2G,推荐 4G;
#更改主机名
hostnamectl set-hostname zbx-server && su
#获取 zabbix 的下载源
rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm
#更换 zabbix.repo 为阿里源
sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' /etc/yum.repos.d/zabbix.repo
#安装服务
yum install -y zabbix-server-mysql zabbix-agent
#安装SCL(Software Collections),便于后续安装高版本的 php,默认 yum 安装的 php 版本为 5.4,版本过低,zabbix 5.0 版本对 php 版本最低要 7.2.0 版本。SCL 可以使得在同一台机器上使用多个版本的软件,而又不会影响整个系统的依赖环境。软件包会安装在 /etc/opt/rh 目录下。
yum install -y centos-release-scl
#修改 zabbix-front 前端源,安装 zabbix 前端环境到 scl 环境下
vim /etc/yum.repo.d/zabbix.repo
[zabbix-frontend]
......
enabled=1 #开启安装源
yum install -y zabbix-web-mysql-scl zabbix-apache-conf-scl
#安装 zabbix 所需的数据库
yum install -y mariadb-server mariadb
systemctl enable --now mariadb #立即开启数据库服务并加入开机自启
mysql_secure_installation #初始化数据库,并设置密码,如 000000
#添加数据库用户,以及 zabbix 所需的数据库信息
mysql -u root -p000000
create database zabbix character set utf8 collate utf8_bin;
grant all on zabbix.* to 'zabbix'@'%' identified by 'zabbix';
flush privileges;
#导入数据库信息
rpm -ql zabbix-server-mysql #查询 sql 文件的位置
zcat /usr/share/doc/zabbix-server-mysql-*/create.sql.gz | mysql -uroot -p000000 zabbix
#修改 zabbix server 配置文件,修改数据库的密码
vim /etc/zabbix/zabbix_server.conf
......
DBPassword=zabbix #124行,指定 zabbix 数据库的密码
#修改 zabbix 的 php 配置文件
vim /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf
......
php_value[date.timezone] = Asia/Shanghai #24行,取消注释,修改时区
#启动 zabbix 相关服务
systemctl re