目录
一、为什么要做监控
二、Zabbix介绍
三、zabbix组成
四、Zabbix主要功能
五、zabbix 监控原理
六、zabbix运行机制
七、Zabbix的监控方式
7.1 主动模式
7.2 被动模式
八、Zabbix监控系统监控对象
九、Zabbix的优缺点
9.1Zabbix的优点
9.2Zabbix的缺点
9.3zabbix主要特点
十、Zabbix程序组件
十一、zabbix的3种架构
10.1server-client架构
10.2server-proxy-client架构
10.3master-node-clinet架构
十二、部署安装 zabbix 5.0
12.1环境准备
12.2获取Zabbix的下载源
12.3更换 zabbix.repo 为阿里源
12.4清空yum缓存并下载 zabbix-server 和 zabbix-agentd(用于监控本机)
①清除原理yum源缓存并加载新的yum
②安装zabbix客户端和服务端
12.5修改 zabbix-front 前端源,安装 zabbix 前端环境到 scl 环境下
12.6安装 zabbix 所需的数据库
12.7初始化数据库,并设置密码,如123123
12.8添加数据库用户,以及 zabbix 所需的数据库信息
12.9导入数据库信息
12.10修改 zabbix server 配置文件,修改数据库的密码
12.11修改 zabbix 的 php 配置文件
12.12启动 zabbix 相关服务
12.13浏览器访问http://192.168.246.8/zabbix
12.14解决 zabbix-server Web页面中文乱码问题
一、为什么要做监控
作为一个运维,需要会使用监控系统查看服务器系统性能、应用服务状态和网站流量指标等,利用监控系统的数据去了解网站上线发布的结果和健康状态
利用一个优秀的监控软件,我们可以:
- 通过一个友好的界面进行浏览整个网站所有的服务器状态(并且是实时展示)
- 可以在 Web 前端方便的查看监控数据
- 可以回溯寻找事故发生时系统的问题和报警情况
二、Zabbix介绍
- zabbix是一个基于web界面的提供分布式系统监视以及网络监视功能的企业级开源解决方案
- zabbix能监视各种网络参数,保证服务器系统的安全运营,并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题
三、zabbix组成
- zabbix有2部分组成:zabbix server与可选组件zabbix agent
- 通过C/S模式采集数据,通过B/S模式在web端展示和配置
- zabbix server可以通过zabbix agent,snmp协议端口等方式提供对远程服务器/网络的监视,数据收集等功能,它可以运行在linux等平台
- zabbix agent需要安装在被监视的目标服务器,它主要完成对硬件信息或与操作系统有关的内存,cpu等信息的收集
四、Zabbix主要功能
CPU 负载 、内存使用、 磁盘使用率 、网络状态 、 端口监视 、日志监视 、插件开发自定义
五、zabbix 监控原理
- zabbix agent安装在被监控的主机上,zabbix agent负责定期收集客户端本地各项数据,并发送至 zabbix server 端,
- zabbix server 收到数据后,将数据存储到数据库中,用户基于 Zabbix WEB 可以看到数据在前端展现图像。
- 当 zabbix 监控某个具体的项目, 该项目会设置一个触发器阈值,当被监控的指标超过该触发器设定的阈值,会进行一些必要的动作,动作包括:发送信息(邮件、微信、短信)、发送命令(shell 命令、reboot、restart、install 等)
六、zabbix运行机制
zabbix是C/S架构由zabbbix server和zabbix agent组成
zabbix server :负责存储展示硬件信息,通过B/S模式传给web端展示配置,端口号10051
zabbix agent :监控收集服务器信息,端口号为10050
zabbix server(端口10051):zabbix服务端进程,用于配置和管理zabbix应用程序,也是监控系统的告警中心(需要配置监控项告警触发阈值和发送告警)
zabbix database:持久化存储配置信息和监控指标数据(支持mysql oracle gpdb tsdb等)
zabbix web:用于zabbix服务端配置界面和监控数据的UI界面展示(支持LAMP/LNMP)
zabbix agent(端口10050):部署在被监控的主机上,采集监控指标数据,并发送给zabbix server(数据采集支持主动模式和被动模式)
七、Zabbix的监控方式
7.1 主动模式
- 主动检测: 相对于agent而言; agent(active),agent向server请求与自己相关监控项配置, 主动地将server配置的监控项相关的数据发送给server;
- 主动监控能极大节约监控server的资源。
7.2 被动模式
- 被动检测:相对于agent而言 ; agent, server向agent请求获取配置的各监控项相关的数据
- agent接收请求、获取数据并响应给server;
主动模式:相对于客户端而言:agent向server发起连接
被动模式:相对于客户端而言:server向agent发起连接
如果你有上千台机器需要监控,采用zabbix的主动模式,被动模式sever端的压力太大了
八、Zabbix监控系统监控对象
九、Zabbix的优缺点
9.1Zabbix的优点
- 开源,无软件成本投入
- Server对设备性能要求低
- 支持设备多,自带多种监控模板
- 支持分布式集中管理,有自动发现功能,可以实现自动化监控
- 开放式接口,扩展性强,插件编写容易
- 当监控的 item 比较多服务器队列此较大时可以采用主动状态,被监控客户端主动从server端去下载需要监控的item然后取数据上传到server端。这种方式对服务器的负载比较小。
- Api的支持,方便与其他系统结合
9.2Zabbix的缺点
- 需在被监控主机上安装agent,所有数据都存在数据库里,产生的数据据很大,瓶颈主要在数据库。
- 项目批量修改不方便。
- 社区虽然成熟,但是中文资料相对较少,服务支持有限。
- 入门容易,能实现基础的监控,但是深层次需求需要非常熟悉Zabbix并进行大量的二次定制开发难度较大。
- 系统级别报警设置相对比较多,如果不筛选的话报警邮件会很多;且自定义的项目报警需要自己设置,过程比较繁琐。
- 缺少数据汇 总功能,如无法查看-组服务器平均值, 需进行二次开发;
优点:基于两款工具(cacti+Nagios)优点于一身并更强大,集数据采集、数据存储、数据展示及报警功能为一体实现企业级分布式监控 缺点:需在被监控主机上安装agent,所有数据都存在数据库里,产生的数据量很大,瓶颈主要在数据库
9.3zabbix主要特点
- 安装配置简单
- 学习成本比较低
- 支持多语言、 包括中文
- 免费开源
- 自动发现服务器与网络设备
- 分布式监控以及web集群中的管理功能
- (邮件、 短信、 语音 、微信、 钉钉 )等功能通知
十、Zabbix程序组件
- Zabbix_ server:服务端守护进程
- Zabbix_ agentd:agent守护进程
- zabbix_ proxy: 代理服务器
- zabbix database: 存储系统,mysql, pgsq|
- Zabbix_ web:web GUI图形化界面
- Zabbix_ get:命令行工具,测试向agent发起数据采集请求
- Zabbix_ sender:命令行工具,测试向server发 送数据
- Zabbix_ java_ gateway: java网关
重要组件: Zabbix由以下几个组件部分构成: zabbix server:负责接收agent发送的报告信息的核心组件,所有配置,统计数据及操作数据均由其组织进行 database storage:专用于存储所有配置信息,以及由zabbix收集的数据 web interface:zabbix的GUI接口,通常与server运行在同一台主机上 proxy:可选组件,常用于分布式监控环境中,代理server收集部分被监控端的监控数据并同意发往server端 agent:部署在被监控主机上,负责收集本地数据并发往server端或proxy端 常见进程 默认情况下zabbix包含5个进程:zabbix_agentd、zabbix_get、zabbix_proxy、zabbix_sender、zabbix_server,另外一个zabbix_java_gataway是可选的,这个需要另外安装。 Zabbix_agentd:客户端守护进程,此进程收集客户端数据,例如cpu负载、内存、磁盘使用情况等。 Zabbix_get:zabbix工具,单独使用的命令,通常在server或者proxy端执行获取远程客户端信息的命令。通常用来排错。例如在server端获取不到客户端的内存数据,可以使用zabbix_get获取客户端内存的方式来做故障排查。 Zabbix_sender:zabbix工具,用于发送数据给server或者proxy,通常用于耗时比较长的检查。很多检查非常耗时,导致zabbix超时。于是我们在脚本执行完毕之后,使用sender主动提交数据。 Zabbix_server:zabbix服务端守护进程。Zabbix_agentd、zabbix_get、zabbix_sender、zabbix_proxy、zabbix_java_gataway的数据最终都是提交到server,并不是数据都是主动提交给zabbix_server,也有的是sever主动去取数据 Zabbix_proxy:zabbix代理守护进程,功能类似server,唯一不同的是它只是一个中转站,它需要把收集到的数据提交/被提交到sever Zabbix_java_gataway:zabbix2.0之后引入的一个功能,顾名思义:java网关,类似agentd,但是只用于java方面。需要特别注意的是,它只能主动取获取数据,而不能被动获取数据。它的数据最终会给到server或者proxy
十一、zabbix的3种架构
在实际监控架构中,zabbix根据网络环境、监控规模等分了三种架构:server-client、master-node-client、server-proxy-client三种
10.1server-client架构
server-client架构
也是zabbix最简单的架构,监控机和被监控机直接不经过任何代理,直接由zabbix server和zabbix agentd之间进行数据交互。适用于网络比较简单,尽量在设备比较少的监控环境。
10.2server-proxy-client架构
server-proxy-client架构
其中proxy是server、client之间沟通的一个桥梁,proxy本身没有前端,而且其本身并不存放数据,而且本身并不存放数据,只是将agentd发来的数据暂时存放,而后再提交给server,该架构经常是和master-node-client架构做比较的架构,一般适用于跨机房、跨网络的中型网络架构的监控,用于大于500台的架构
10.3master-node-clinet架构
Master-Node-Client该架构
是Zabbix最复杂的监控架构,适用于跨网络、跨机房、设备多的大型环境。每个Node同时接一个Sever端,Node下面可以接Proxy端,也可以直接连接Client,Node有自己的配置文件和数据库,其要做的是将配置信息和监控数据向Master进行数据同步,Master故障损坏对Node其下架构的完整性无任何影响
在实际监控架构中,zabbix根据网络环境、监控规模等分了三种架构:server-client、master-node-client、server-proxy-client三种。 server-client架构 也是zabbix最简单的架构,监控机和被监控机直接不经过任何代理,直接由zabbix server和zabbix agentd之间进行数据交互。适用于网络比较简单,设备比较少的监控环境。 server-proxy-client架构 其中proxy是server、client之间沟通的一个桥梁,proxy本身没有前端,而且其本身并不存放数据,只是将agentd发来的数据暂时存放,而后再提交给server。该架构经常是和master-node-client架构做比较的架构,一般适用于跨机房、跨网络的中型网络架构的监控 master-node-clinet架构 该架构是zabbix最复杂的监控架构,适用于跨网络、跨机房、设备较多的大型环境。每个node同时也是一个server端,node下面可以接proxy,也可以直接接client。Node有自己的配置文件和数据库,其要做的是将配置信息和监控数据向master同步
十二、部署安装 zabbix 5.0
12.1环境准备
zabbix-server 内存至少 2G,推荐 4G
一台2核4G内存数据库,至少2核2G
服务器类型 | 系统和IP地址 | 备注 |
---|---|---|
server服务器 | CentOS7.4(64 位) 192.168.246.8 | 4G内存、zabbix-server-mysql、zabbix-agent、centos-release-scl |
systemctl disable --now firewalld
#永久关闭并现在立即关闭防火墙
setenforce 0
#关闭selinux
hostnamectl set-hostname 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下载yum源
cd /etc/yum.repos.d
sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' zabbix.repo
vim zabbix.repo
#编辑配置文件 开启安装源
[zabbix-frontend]
......
enabled=1 #1表示开启安装源
......
#进入yum源目录文件并使用sed将国外源替换为阿里云源
yum clean all && yum makecache
#清除原理yum源缓存并加载新的yum
yum install -y zabbix-server-mysql zabbix-agent
#安装zabbix客户端和服务端
yum install -y centos-release-scl
#安装scl,原因为便于后续安装高版本的 php,默认 yum 安装的 php 版本为 5.4zabbix要求php版本为7.2以上,若达到要求则无须安装scl
yum install -y zabbix-web-mysql-scl zabbix-apache-conf-scl
#安装连接数据库和连接apache前端页面的连接工具
yum install -y mariadb-server mariadb
systemctl enable --now mariadb
#安装并开启数据库
mysql_secure_installation
#初始化数据库,并设置密码,如 abc123选择执行,先回车,然后输入2次自己想设置的密码,其他全部yes即可
CREATE DATABASE zabbix character set utf8 collate utf8_bin;
#创建zabbix库并设置库格式为utf-8
GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';
#创建并授权zabbix远程登录用户密码为zabbix
flush privileges;
#刷新数据
rpm -ql zabbix-server-mysql
#查询zabbix数据库中配置文件的位置
zcat /usr/share/doc/zabbix-server-mysql-5.0.33/create.sql.gz | mysql -uroot -pabc123 zabbix(导入的库名)
#将zabbix数据库格式导入数据库中,此处需要等待10s左右
vim /etc/zabbix/zabbix_server.conf
DBPassword=zabbix #124行,去掉#注释然后指定 zabbix 数据库的密码
#编辑zabbix配置文件将设置的远程登录用户的密码zabbix输入进去保存退出
vim /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf
php_value[date.timezone] = Asia/Shanghai #24行,取消注释,修改时区
#编辑php的配置文件,将时区改为亚洲上海,注意去掉前面的;在此文件中表示注释
systemctl restart zabbix-server zabbix-agent httpd rh-php72-php-fpm
systemctl enable zabbix-server zabbix-agent httpd rh-php72-php-fpm
#重启zabbix服务php服务并设置开机自启
所有服务器关闭防火墙、关闭防护、修改主机名
systemctl disable --now firewalld
setenforce 0
hostnamectl set-hostname zbx-server
12.2获取Zabbix的下载源
rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm
12.3更换 zabbix.repo 为阿里源
cd /etc/yum.repos.d
sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' zabbix.repo
将官方源替换为阿里源,下载速度更快
12.4清空yum缓存并下载 zabbix-server 和 zabbix-agentd(用于监控本机)
①清除原理yum源缓存并加载新的yum
yum clean all && yum makecache
②安装zabbix客户端和服务端
yum install -y zabbix-server-mysql zabbix-agent
yum install -y centos-release-scl
安装SCL(Software Collections),便于后续安装高版本的 php,默认 yum 安装的 php 版本为 5.4,版本过低,zabbix 5.0 版本对 php 版本最低要 7.2.0 版本。SCL 可以使得在同一台机器上使用多个版本的软件,而又不会影响整个系统的依赖环境。
软件包会安装在 /opt/rh 目录下
12.5修改 zabbix-front 前端源,安装 zabbix 前端环境到 scl 环境下
yum install -y zabbix-web-mysql-scl zabbix-apache-conf-scl
12.6安装 zabbix 所需的数据库
yum install -y mariadb-server mariadb
systemctl enable --now mariadb
12.7初始化数据库,并设置密码,如123123
mysql_secure_installation
12.8添加数据库用户,以及 zabbix 所需的数据库信息
CREATE DATABASE zabbix character set utf8 collate utf8_bin;
GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';
flush privileges;
12.9导入数据库信息
zcat /usr/share/doc/zabbix-server-mysql-5.0.42/create.sql.gz |mysql -uroot -p123123 zabbix
12.10修改 zabbix server 配置文件,修改数据库的密码
vim /etc/zabbix/zabbix_server.conf
......
DBPassword=zabbix #124行,指定 zabbix 数据库的密码
12.11修改 zabbix 的 php 配置文件
vim /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf
......
php_value[date.timezone] = Asia/Shanghai #24行,取消注释,修改时区
12.12启动 zabbix 相关服务
systemctl restart zabbix-server zabbix-agent.service httpd rh-php72-php-fpm.service
systemctl enable zabbix-server zabbix-agent.service httpd rh-php72-php-fpm.service
12.13浏览器访问http://192.168.246.8/zabbix
点击下一步,设置数据库的密码 zabbix
安装完成后,默认的登录账号和密码为:Admin/zabbix
设置文件界面:点击左边菜单栏的【User settings】,【Language】选择 Chinese(zh_CN),再点击 Update 更新
①浏览器输入自己部署zabbix地址的服务器地址如本机:http://192.168.246.8/zabbix进入配置页面
②点击netxt step进入下一步检查zabbix配置,所有状态都要为ok,若有问题则需要去服务器侧检查配置
③所有配置都正常则继续点击下一步使用zabbix账户登录数据库
④连接数据库后下一步配置zabbix信息
⑤ 配置完成zabbix后检查配置项然后点击下一步保存安装
⑥信息检查完成后点击结束安装完成
⑦结束后登录验证,默认账户为:Admin 默认密码为:zabbix
⑧登录完成后主页面如下
⑨修改zabbix语言为中文,点击user settings然后选择语言为中文,点击update保存即可
12.14解决 zabbix-server Web页面中文乱码问题
yum install -y wqy-microhei-fonts
\cp -f /usr/share/fonts/wqy-microhei/wqy-microhei.ttc /usr/share/fonts/dejavu/DejaVuSans.ttf
再次刷新查看