对于运维人员来说,监控是非常重要的,因为如果想要保证线上业务整体能够稳定运行,那么我们则需要实时关注与其相关的各项指标是否正常,而一个业务系统的背后,往往存在着很多的服务器、网络设备等硬件资源,如果我们想要能够更加方便的、集中的监控他们,我们则需要依靠一些外部的工具,而 zabbix 就是一个被广泛使用的,可以实现集中监控管理的应用程序。
我们监控的初衷就是当某些指标不符合我们的需求时,我们能够在第一时间发现异常,所以,监控工具需要定期的对被监控主机进行检查、信息收集等操作,当被监控主机出现异常时,能够及时报警、通知管理员,并且需要记录这些异常,以便我们分析这些数据,查漏补缺,那么,一个监控工具就应该具备采集信息、存储信息、展示信息、报警通知等功能,而 zabbix 就可以做到这些,除了 zabbix,你可能还听说过 cacti、nagios、ganglia 等类似的监控系统,但是此处,我们只聊 zabbix。
那么 zabbix 能够支持哪些通讯方式呢,总结如下:
agent: 通过专用的代理程序进行监控,与常见的 master/agent 模型类似, 如果被监控对象支持对应的 agent,推荐首选这种方式。
ssh/telnet: 通过远程控制协议进行通讯,比如 ssh 或者 telnet。
SNMP: 通过 SNMP 协议与被监控对象进行通讯,SNMP 协议的全称为 Simple Network Management Protocol , 被译为 “简单网络管理协议”,通常来说,我们无法在路由器、交换机这种硬件上安装 agent,但是这些硬件往往都支持 SNMP 协议,SNMP 是一种比较久远的、通行的协议,大部分网络设备都支持这种协议,其实 SNMP 协议的工作方式也可以理解为 master/agent 的工作方式,只不过是在这些设备中内置了 SNMP 的 agent 而已,所以,大部分网络设备都支持这种协议。
IPMI: 通过 IPMI 接口进行监控,我们可以通过标准的 IPMI 硬件接口,监控被监控对象的物理特征,比如电压,温度,风扇状态,电源状态等。
JMX: 通过 JMX 进行监控,JMX(Java Management Extensions,即 Java 管理扩展),监控 JVM 虚拟机时,使用这种方法也是非常不错的选择。
好了,我们刚才提到了 zabbix agent,一般情况下,我们将 zabbix agent 部署到被监控主机上,由 agent 采集数据,报告给负责监控的中心主机,中心主机也就是 master/agent 模型中的 master,负责监控的中心主机被称为 zabbix server,zabbix server 将从 agent 端接收到的信息存储于 zabbix 的数据库中,我们把 zabbix 的数据库端称为 zabbix database, 如果管理员需要查看各种监控信息,则需要 zabbix 的 GUI,zabbix 的 GUI 是一种 Web GUI,我们称之为 zabbix web,zabbix web 是使用 php 编写的,所以,如果想要使用 zabbix web 展示相关监控信息,需要依赖 LAMP 环境,不管是 zabbix server ,或是 zabbix web,他们都需要连接到 zabbix database 获取相关数据,这样说可能不容易理解,对比下图理解上述概念,就容易许多
zabbix agent: 部署在被监控主机上,负责被监控主机的数据,并将数据发送给 zabbix server。
zabbix server: 负责接收 agent 发送的报告信息,并且负责组织配置信息、统计信息、操作数据等。
zabbix database: 用于存储所有 zabbix 的配置信息、监控数据的数据库。
zabbix web: zabbix 的 web 界面,管理员通过 web 界面管理 zabbix 配置以及查看 zabbix 相关监控信息,可以单独部署在独立的服务器上。
zabbix proxy: 可选组件,用于分布式监控环境中,zabbix proxy 代表 server 端,完成局部区域内的信息收集,最终统一发往 server 端。
了解完了 zabbix 的几个核心组件,我们再来聊聊 zabbix 的工作模式。
我们知道,agent 端会将采集完的数据主动发送给 server 端,这种模式我们称之为主动模式,即对于 agent 端来说是主动的。
其实,agent 端也可以不主动发送数据,而是等待 server 过来拉取数据,这种模式我们称之为被动模式。
聪明如你一定已经明白,不管是主动模式还是被动模式,都是对于 agent 端来说的,而且,主动模式与被动模式可以同时存在,并不冲突。
管理员可以在 agent 端使用一个名为 zabbix_sender 的工具,测试是否能够向 server 端发送数据。
管理员可以在 server 端使用一个名为 zabbix_get 的工具,测试是否能够从 agent 端拉取数据。
好了,我们已经了解了 zabbix 的一些基本概念,其实 zabbix 还有很多常用术语,但是现在我们并没有遇到实际的使用场景,空口白话的描述显得特别无力,而且难以理解,我们就先不管它们了,等到用到它们的时候,我们再做解释。
直达链接:zabbix安装