Zabbix搭建和模板配置
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/zabbixhttp://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的具体操作方法可以百度。
设置收件人——记得点击更新
相关文章
- 还在手动盖楼领喵币?双十一这群开发者竟然如此「作弊」
- 我们为什么要关注量子霸权?量子霸权意味着什么?
- GitLab,是谁给了你歧视中国程序员的勇气?
- GitLab也开始国家封锁?部分职位对中国、俄罗斯关闭,引社区热议
- 又有免费GPU资源了:可直接跑Jupyter Notebook,还支持断点续命
- 详解三种主流分布式事务方案的优劣
- Github标星10.4K!Chrome好用的插件都在这里了
- IT 人眼里最吃香的技术:软件开发 JavaScript;数据专业 R等
- 漫画说算法之什么是一致性哈希?
- Linus Torvalds 认为自己不再是一名程序员
- 什么是Docker?与虚拟机有什么区别?
- 分布式技术“上位”进行时
- 程序员们该如何破局!
- 程序员节Keep被曝突然裁员300多人,60%是开发和运营
- 程序员报告:男性占比超87% 北京月薪12184元最高
- 1024特别版:向“程序媛们”致敬!
- 你不想错过的那些JSON工具
- Gartner 2020年十大战略性技术趋势:超级自动化、分布式云、AI安全等
- 运维别走,留下你的root权限
- 从0到1设计一个MQ消息队列