什么是Zabbix

Zabbix 是一款监控网络的众多参数以及服务器、虚拟机、应用程序、服务、数据库、网站、云等的健康和完整性的软件。Zabbix 使用灵活的通知机制,允许用户为几乎任何事件配置基于电子邮件的告警,以实现对服务器问题做出快速反应。Zabbix 基于存储的数据提供出色的报告和数据可视化功能。这使得 Zabbix 成为容量规划的理想选择。

Zabbix 支持轮询和 trapping。所有 Zabbix 报告和统计数据以及配置参数都可以通过基于 Web 的前端访问。基于 Web 的前端确保可以从任何位置评估您的网络状态和服务器的健康状况。如果配置得当,不管对于拥有少量服务器的小型组织还是拥有大量服务器的大公司来讲,Zabbix 都可以在监控 IT 基础设施方面发挥重要作用。

Agent

Zabbix agent 部署在被监控目标上,以主动监控本地资源和应用程序(硬盘、内存、处理器统计信息等)。

Zabbix agent 收集本地的操作信息并将数据报告给 Zabbix server 用于进一步处理。一旦出现异常 (例如硬盘空间已满或者有崩溃的服务进程),Zabbix server 会主动警告管理员指定机器上的异常。

Zabbix agents 的极高效率缘于它可以利用本地系统调用来完成统计数据的采集。

收集方式

在被动检查模式中 agent 应答数据请求。Zabbix server(或 proxy)询求数据,例如 CPU load,然后 Zabbix agent 返还结果。

主动检查 处理过程将相对复杂。Agent 必须首先从 Zabbix sever 索取监控项列表以进行独立处理,然后会定期发送采集到的新值给 Zabbix server。

是否执行被动或主动检查是通过选择相应的监控项类型来配置的。 Zabbix agent 处理“Zabbix agent”或“Zabbix agent(active)”类型的监控项。

Server

Zabbix server 是整个 Zabbix 软件的核心程序。

Zabbix Server 负责执行数据的主动轮询和被动获取,计算触发器条件,向用户发送通知。它是 Zabbix Agent 和 Proxy 报告系统可用性和完整性数据的核心组件。Server 自身可以通过简单服务远程检查网络服务(如Web服务器和邮件服务器)。

Zabbix Server是所有配置、统计和操作数据的中央存储中心,也是Zabbix监控系统的告警中心。在监控的系统中出现任何异常,将被发出通知给管理员。

基本的 Zabbix Server 的功能分解成为三个不同的组件。他们是:Zabbix server、Web前端和数据库。

Zabbix 的所有配置信息都存储在 Server 和Web前端进行交互的数据库中。例如,当你通过Web前端(或者API)新增一个监控项时,它会被添加到数据库的监控项表里。然后,Zabbix server 以每分钟一次的频率查询监控项表中的有效项,接着将它存储在 Zabbix server 中的缓存里。这就是为什么 Zabbix 前端所做的任何更改需要花费两分钟左右才能显示在最新的数据段的原因。

Proxy

Zabbix proxy 是一个可以从一个或多个受监控设备采集监控数据并将信息发送到 Zabbix server 的进程,主要是代表 Zabbix server 工作。 所有收集的数据都在本地缓存,然后传输到 proxy 所属的 Zabbix server。

部署Zabbix proxy 是可选的,但可能非常有利于分担单个 Zabbix server 的负载。 如果只有代理采集数据,则 Zabbix server 上会减少 CPU 和磁盘 I/O 的开销。

Zabbix proxy 是无需本地管理员即可集中监控远程位置、分支机构和网络的理想解决方案。

Zabbix proxy 需要使用独立的数据库。

 Java 网关

从 Zabbix 2.0 开始,以 Zabbix 守护进程方式原生支持监控 JMX 应用程序就存在了,称之为“Zabbix Java gateway”。Zabbix Java gateway 的守护进程是用 Java 编写。为了在特定主机上找到 JMX 计数器的值,Zabbix server 向 Zabbix Java gateway 发送请求,后者使用 JMX 管理 API 来远程查询相关的应用。该应用不需要安装额外的软件。只需要在启动时,命令行添加-Dcom.sun.management.jmxremote选项即可。

 JS

zabbix_js 是一个命令行实用程序,可用于嵌入脚本测试。

该程序可执行带有字符串参数的用户自定义脚本并打印结果。脚本的执行是由内嵌的Zabbix脚本引擎来完成的。

在编译或执行错误的情况下,zabbix_js将在stderr中打印错误并以代码1退出。

Zabbix优势:

数据采集:可用性和性能检测,自动发现,支持agent、snmp、JMX、telnet等多种采集方式,支持主动和被动模式数据传输、支持用户自定义插件,自定义间隔收集数据。

高可用:server对设备性能要求低,支持proxy分布式监控,分布式集中管理,有自动发现功能,可以实现自动化监控,开放式接口,扩展性强,插件编写容易。

告警管理:支持多条件告警,支持多种告警方式,支持多组模版,模版继承。

告警设置:告警周期,告警级别,告警恢复通知,告警暂停,时段阈值,支持维护周期,支持单机停用。

图形化展示:获取到到数值型到数据,可自动生成图,允许自定义创建多监控项视图,网络拓扑,自定义面板展示,自定义IT服务可用性。

历史数据:历史数据查询可配置,内置housekeeping数据清理机制。

安全审计:具备安全对用户审计日志,权限认证,用户可以限制允许维护对列表。

 操作快捷:使用了与Nagios/Cacti相比较先进到Web前端技术,可以通过Web界面设置或查看监视结果;或者通过Graphs+Screens的方式可以按需聚合信息。在添加监控项目或者机器到时候十分迅速,操作易用性较好。

Zabbix的部署与配置

systemctl disable --now firewalld

setenforce 0

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.repo 为阿里源 cd /etc/yum.repos.d

sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' zabbix.repo

yum clean all && yum makecache

yum install -y zabbix-server-mysql zabbix-agent

yum install -y centos-release-scl

vim 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       #初始化数据库,并设置密码

//添加数据库用户,以及 zabbix 所需的数据库信息

mysql -u root -pabc123

//启动 zabbix 相关服务

systemctl restart zabbix-server zabbix-agent httpd rh-php72-php-fpm

systemctl enable zabbix-server zabbix-agent httpd rh-php72-php-fpm

//解决 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

企业级应用架构监控_数据库

企业级应用架构监控_数据库_02

企业级应用架构监控_企业级应用架构监控_03

企业级应用架构监控_数据_04

 

企业级应用架构监控_大数据_05

 

zabbix-agent客户端安装与配置

[root@localhost ~]# tar -zxf zabbix-3.4.8.tar.gz

[root@localhost ~]# cd zabbix-3.4.8/

[root@localhost zabbix-3.4.8]# pwd /root/zabbix-3.4.8

编译安装

./configure --prefix=/usr/local/zabbix --enable-agent make && make install

切换/usr/local/zabbix/etc/下修改zabbix_agentd.conf文件。主要修改一下参数

cat >/usr/local/zabbix/etc/zabbix_agentd.conf<<EOF

LogFile=/tmp/zabbix_agentd.log

Server=19.168.100.14

ServerActive=192.168.100.14

Hostname=192.168.100.15

EOF

切换到zabbix解压目录,拷贝zabbix_agentd启动脚本到/etc/init.d/目录

[root@localhost ~]# cd zabbix-3.4.8/

[root@localhost zabbix-3.4.8]# pwd /root/zabbix-3.4.8

[root@localhost zabbix-3.4.8]# cp misc/init.d/tru64/zabbix_agentd

/etc/init.d/zabbix_agentd

设置/etc/init.d/zabbix_agentd执行权限

[root@localhost zabbix-3.4.8]# chmod o+x /etc/init.d/zabbix_agentd

启动zabbix_agentd服务

/etc/init.d/zabbix_agentd start #开启服务

/etc/init.d/zabbix_agentd stop #关闭服务

/etc/init.d/zabbix_agentd restart #重起服务

企业级应用架构监控_大数据_06

 

企业级应用架构监控_数据库_07

 

企业级应用架构监控_Web_08

 

企业级应用架构监控_Web_09

客户端配置

 linux 命令

who | wc -l 

创建 zabbix 的监控项配置文件,用于自定义 key

vim /etc/zabbix/zabbix_agent2.conf

268 Include=/etc/zabbix/zabbix_agent2.d/*.conf

#自定义监控项的格式如下 291 

Format: UserParameter=<key>,<shell command>

cd /etc/zabbix/zabbix_agent2.d/

vim UserParameter_login.conf

UserParameter=login.user,who|wc -l

systemctl restart zabbix-agent2

在服务端验证新建的监控项

zabbix_get -s '192.168.80.20' -p 10050 -k 'login.user'

企业级应用架构监控_大数据_10

企业级应用架构监控_数据库_11

企业级应用架构监控_Web_12