zabbix源码目录结构
|-- bin // 包含Windows下对zabbix_sender进行二次开发所需要的头文件与库 |-- build // 包含Windows下的编译文件,二进制程序文件等 |-- conf // agent,proxy,server的配置文件 |-- database // 数据库脚本 |-- frontends // PHP前端 |-- include // zabbix公共头文件(*) |-- m4 // 依赖第三方库的说明文件 |-- man // 使用手册 |-- misc // 包含图片,脚本等杂项文件 |-- sass `-- src // zabbix的实现源码文件 |-- libs // zabbix公共基础模块的代码(*) |-- modules // zabbix可加载模块的开发示例 | `-- dummy |-- zabbix_agent // zabbix客户端源码文件,主要是包括数据自动收集、被动监控和自动发送数据(*) |-- zabbix_get // zabbix_get工具的源码 |-- zabbix_java // Java网关的源码 |-- zabbix_proxy // zabbix代理模块源码文件 | |-- datasender | |-- heart | |-- housekeeper | |-- proxyconfig | `-- taskmanager |-- zabbix_sender // zabbix_sender工具的源码 `-- zabbix_server // zabbix服务端源码.每个子目录对应服务端一种子进程(*) |-- alerter |-- dbconfig |-- dbsyncer |-- discoverer |-- escalator |-- housekeeper |-- httppoller |-- ipmi |-- odbc |-- pinger |-- poller |-- preprocessor |-- proxypoller |-- scripts |-- selfmon |-- snmptrapper |-- taskmanager |-- timer |-- trapper `-- vmware
上面的源码目录结构中,需要我们重点关注的源码目录有:include
,libs
,zabbix_agent
,zabbix_server
,已用“*”标注了出来。
zabbix整体架构图
zabbix的整体架构如下图所示:
组件说明:
-
Zabbix Server:可以通过SNMP,zabbix agent,ping,端口监视等方法提供对远程服务器/网络状态的监视,数据收集等功能。
-
DataBase:专用于存储所有配置信息,以及由zabbix收集的数据。
-
Web GUI:zabbix前端操作界面。
-
Zabbix Proxy:可选组件,常用于监控节点很多的分布式环境中,代理server收集部分数据转发到server,可以减轻server的压力。
-
Zabbix Agent:部署在被监控的主机上,负责收集主机本地数据如cpu、内存、数据库等指标发往server端或proxy端。