1.zabbix基础搭建
Zabbix 是由 Alexei Vladishev 开发的⼀种⽹络监视、管理系统,基于 Server-Client 架构。可⽤于监视各种⽹络服务、服务器和⽹络机器等状态。 使⽤各种 Database-end 如 MySQL, PostgreSQL, SQLite, Oracle 或 IBM DB2 储存资料。Server 端基于 C语⾔、Web 管理端 frontend 则是基于 PHP 所 制作的。 Zabbix 可以使⽤多种⽅式监视。可以只使⽤ Simple Check 不需要安装 Client 端,亦可基于 SMTP 或 HTTP ... 各种协议定制监视。 在客户端如 UNIX, Windows 中安装 Zabbix Agent 之后,可监视 CPU Load、⽹络使⽤状况、硬盘容量等各种状态。⽽就算没有安装 Agent 在监视对象 中,Zabbix 也可以经由 SNMP、TCP、ICMP、利⽤ IPMI、SSH、telnet 对⽬标进 ⾏监视。 Zabbbix⾃带的Item⾜够满⾜普通⼩公司的监控需求,对于⼤公司也可以设定⾃定义 的Item,⾃动⽣成报表,也有API可以和其他系统集成
zabbix就是可以满⾜理想化的监控系统需求
⽀持⾃定义监控脚本,提供需要输出的值即可 zabbix存储的数据库表结构稍有复杂但是逻辑清晰 zabbix存在模板的概念,可以⽅便的将⼀组监控项进⾏部署 zabbix每⼀个item也就是监控项,都可以看到历史记录,且web界⾯友好 zabbix有强⼤的Trigger(触发器)定义规则,可以定义复杂的报警逻辑 zabbix提供了ack报警确认机制 zabbix⽀持邮件,短信,微信等告警 zabbix在触发告警后,可以远程执⾏系统命令 zabbix有原⽣的PHP绘图模块
1)基础配置
准备三台虚拟机,搭建zabbix的服务器的配置要在2h2g+,另外两台无所谓
虚拟机名称 | 虚拟机ip | 虚拟机配置 |
zabbix_server | 192.168.200.131 | 2H2G100G |
zabbix_agent1 | 192.168.200.132 | 无要求 |
zabbix_agent2 | 192.168.200.133 | 无要求 |
三台虚拟机都进行如下操作:修改名称——关闭防火墙——配置yum源
1.1修改虚拟机名称
将三台虚拟机修改成指定名称
1.2关闭防火墙
systemctl stop firewalld systemctl disable firewalld setenforce 0 sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config
1.3配置yum源
rm -rf /etc/yum.repos.d/CentOS-*#删除默认yum源 curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo#设置阿里云yum源 rpm -Uvh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm#获取阿里云官方的zabbix包 sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' /etc/yum.repos.d/zabbix.repo#添加repo源 yum clean all && yum repolist#查看yum源是否配置成功
2)yum安装zabbix
此操作只需要在安装zabbix的server端即可。
yum install zabbix-server-mysql zabbix-agent -y#安装zabbix yum install centos-release-scl -y#安装rh插件
注意:安装 Software Collections,便于后续安装⾼版本的 php,默认 yum 安装的 php 版本为 5.4 过低。 SCL(Software Collections)可以让你在同⼀个操作系统上安装和使⽤多个 版本的软件,⽽不会影响整个系统的安装包。 软件包会安装在/opt/rh⽬录下 为了避免系统⼴泛冲突,/opt/rh包安装在⽬录中,例如,这允许你在CentOS 7机器上安装Python 3.5,⽽不会删除或⼲扰Python 2.7. /etc/opt/rh/软件包的所有配置⽂件都存储在⽬录中相应的⽬录中,SCL包 提供了定义使⽤所包含应⽤程序所需的环境变量的shell脚本,例如,PATH, LD_LIBRARY_PATH和MANPATH ,这些脚本存储在⽂件系统中,作为 /opt/rh/package-name/enable 。
3)配置前端源
3.1修改zabbix前端yum源
vim /etc/yum.repos.d/zabbix.repo#进入repo配置文件
3.2安装zabbix前端环境
yum install zabbix-web-mysql-scl zabbix-nginx-conf-scl -y#前端环境 yum install mariadb-server -y#安装mariadb数据库 systemctl enable --now mariadb#设置mariadb开机自启
3.3配置数据库
安装数据,创建用户,给予权限,导入zabbix的表。
mysql_secure_installation#初始化数据库 Enter current password for root (enter for none): #输入密码,因为没有密码直接回车 Set root password? [Y/n] y#是否设置密码 Remove anonymous users? [Y/n] y#删除其他数据库用户 Disallow root login remotely? [Y/n] n#是否禁止远程登录管理员账号 Remove test database and access to it?[y/n]#是否删除test数据库 Reload privilege tables now? [Y/n] y#是否重载权限表
登录数据库,使⽤root⽤户登录mariadb,建⽴zabbix数据库,这⾥的编码设置,⾮常重要,否则zabbix⽆法安装。
create database zabbix character set utf8 collate utf8_bin; #创建zabbix库,字符设置为uft8,区分大小写 create user zabbix@localhost identified by 'zabbix'; #创建用户zabbix,本地登录,密码为zabbix grant all privileges on zabbix.* to zabbix@localhost; #在zabbix库中所有表,所有的权限给zabbix用户 flush privileges; #刷新用户 quit; #退出
导入表。默认数据库没有任何文件,在yum安装时,给我们下载了zabbix的一些sql文件,我们自己导入才能使用他的网页和组件。
zcat /usr/share/doc/zabbix-server-mysql*/create.sql.gz | mysql -uzabbix -pzabbix zabbix #zcat: 不打开压缩包查看其中文件 #-uzabbix: 用户 #-pzabbix: 密码 #zabbix: 库
修改数据库密码和时间。
vim /etc/zabbix/zabbix_server.conf#设置数据库密码 DBPassword=zabbix
4)配置zabbix
#设置地区 vim /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf listen.acl_user = apache,nginx#我们这里用nginx来启动网页,因为没有安装apache服务,所以这里要添加nginx php_alue[date.timezone] = Asia/Shanghai #记得将前面的 ; 去掉
#设置网站服务器
vim /etc/opt/rh/rh-nginx116/nginx/conf.d/zabbix.conf listen 80;#监听nginx的80端口 server_name 192.168.200.131;#设置ip
5)设置自启
systemctl restart zabbix-server zabbix-agent rh-nginx116-nginx rh-php72-php-fpm systemctl enable zabbix-server zabbix-agent rh-nginx116-nginx rh-php72-php-fpm
访问网页
这是我自己的虚拟机IP哦~
http://192.168.200.131/zabbix
6)网页配置
出现该界面就算成功
检查先决条件。查看你php配置是否有问题
配置连接数据库
后面的下一步就可以了。
登录账号为 Admin,密码:zabbix,注意⼤⼩写
2.zabbix基础使用
进入界面后,设置页面为中文
1)基础配置
zabbix就是监控系统,所以我们需要添加一些机器。
zabbix_agent1和zabbix_agent2已经配置好了yum源,所以直接yum安装即可。
1.1安装所需的工具
安装时间同步工具
yum install ntpdate -y#安装时间同步工具 ntpdate -u ntp.aliyun.com#时间源设置为阿里云的 mv /etc/localtime{,.bak} ln -s /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
安装所需要的工具包
yum install zabbix-agent2 -y#安装agent2,绑定zabbix监控机所需要的工具 netstat -tunlp|grep zabbix#查看是否开启
1.2修改配置文件
修改配置文件
vim /etc/zabbix/zabbix_agent2.conf#修改配置文件 #将下面三行修改 Server=192.168.200.131#修改为zabbix_server的ip ServerActive=192.168.200.131#修改为zabbix_server的ip Hostname=zbz-agent01#修改为当前主机的名称 #保存退出 systemctl restart zabbix-agent2#重启服务
1.3检测server机器的连通性
在zabbix_server进行如下操作
yum install zabbix-get -y#安装所需的工具 zabbix_get -s '192.168.200.132' -p 10050 -k "agent.ping" #1 zabbix_get -s '192.168.200.132' -p 10050 -k "system.hostname" #zabbix_agent1
可以看到,zabbix默认监控了server主机。并且可用性的ZBX也显示了。就代表监控成功。并且可以通过点击 “图形” 来查看图形化界面。
解决乱码问题
zabbix是国外公司编写的,其中的ttf文字对于一些页面的中文不兼容,所以需要我们进行替换修改。
yum -y install wqy-microhei-fonts#安装字体 cp /usr/share/fonts/wqy-microhei/wqy-microhei.ttc /usr/share/fonts/dejavu/DejaVuSans.ttf#替换字体文件
2)添加客户端主机
添加监控模板
添加客户端主机1
添加完后,ZBX显示了,即为添加成功。尝试给zabbix_agent2。
3)zabbix查看客户机cpu动态
点击进入图形化界面
下拉查看
4)自定义
zabbix⾃带模板 Template OS Linux (Template App Zabbix Agent) 提供CPU、内存、磁 盘、⽹卡等常规监控,只要新加主机关联此模板,就可⾃动添加这些监控项。
4.1制作模板
需求:限制登录⼈数不超过三个,超过三⼈则发出报警
服务器不希望有太多⼈在操作,除了管理员以外的⼈,⼈数超了,我就怀疑有问题, 需要看看是谁,防⽌他乱操作服务器,给我们运维背锅呀。
自定义key
#zabbix⾃带的key zabbix_get -s '192.168.200.132' -p 10050 -k "system.uname" zabbix_get -s '192.168.200.132' -p 10050 -k "system.hostname" #如果写错了key,会报错
我们可以通过查看监控项,看看都有哪些key
自行查看键值
自定义监控语法
who |wc -l#显示登录人数 vim /etc/zabbix/zabbix_agent2.d/userparameter_login.conf UserParameter=login.user,who|wc -l systemctl restart zabbix-agent2#重启agent zabbix_get -s '192.168.200.132' -p 10050 -k "login.user" #通过命令检测是否成功
5)创建模板
5.1查看服务器有多少在线用户
添加模板
找到创建的模板
点击,添加应用集
创建触发器
创建图形
配置——主机——客户机——添加模板
查看仪表盘数据
查看客户机1的图形化界面
查看仪表盘
5.2查看nginx状态
生成状态监控界面
./configure --with-http_stub_status_module#安装状态监控模块 vim /usr/local/nginx/conf/nginx.conf#进入配置文件 #添加字段 locahost /nginx_status { stub_status on; } systemctl restart nginx#重启nginx curl http://192.168.218.156/nginx_status
配置脚本
yum install -y zabbix_agent2#安装agent2 mkdir /etc/zabbix/scripts/#创建存储脚本的文件夹 vim /etc/zabbix/scripts/nginx_status #!/bin/bash function active { /usr/bin/curl "http://192.168.218.156/nginx_status" 2>/dev/null| grep 'Active' | awk '{print $NF}' } function reading { /usr/bin/curl "http://192.168.218.156/nginx_status" 2>/dev/null| grep 'Reading' | awk '{print $2}' } function writing { /usr/bin/curl "http://192.168.218.156/nginx_status" 2>/dev/null| grep 'Writing' | awk '{print $4}' } function waiting { /usr/bin/curl "http://192.168.218.156/nginx_status" 2>/dev/null| grep 'Waiting' | awk '{print $6}' } function accepts { /usr/bin/curl "http://192.168.218.156/nginx_status" 2>/dev/null| awk NR==3 | awk '{print $1}' } function handled { /usr/bin/curl "http://192.168.218.156/nginx_status" 2>/dev/null| awk NR==3 | awk '{print $2}' } function requests { /usr/bin/curl "http://192.168.218.156/nginx_status" 2>/dev/null| awk NR==3 | awk '{print $3}' } $1 vim /etc/zabbix/zabbix_agent2.d/nginx_zabbix.conf#创建监控文件 UserParameter=nginx[*],/etc/zabbix/scripts/nginx_status $1 chmod 755 /etc/zabbix/scripts/nginx_status#设置权限 systemctl restart zabbix_agent2 #此时就可以通过server节点查看该节点的脚本 zabbix_get -s 192.168.218.156 -k 'nginx[accepts]'
配置zabbix模板
创建模板——模板名称(自定义)——设置群组
应用集——创建应用集——名称(自定义)
监控项——创建监控项——将7个函数添加进去
触发器——创建触发器——根据自己情况添加
图形——创建图形——将7个监控项添加进去
3.zabbix进阶
1)邮件报警
qq邮箱开启SMTP的具体操作方法可以百度。
设置收件人——记得点击更新
配置结束。