【ZABBIX】-1 zabbix的简要介绍
文章目录1、ZABBIX了解1.1 zabbix1.2 zabbix 6.0特性1.3 功能组件1.4 zabbix工作过程1.5 总结1、ZABBIX了解1.1 zabbixzabbix 是什么●zabbix 是一个基于 Web 界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。●zabbix 能监视各种网络参数保证服务器系统的安全运营并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。●zabbix 由 2 部分构成zabbix server 与可选组件 zabbix agent。通过 C/S 模式采集数据通过 B/S 模式在 Web 端展示和配置。●zabbix server 可以通过 zabbix agentSNMP协议端口监视等方法提供对远程服务器/网络状态的监视数据收集等功能它可以运行在 Linux 等平台上。●zabbix agent 需要安装在被监视的目标服务器上它主要完成对硬件信息或与操作系统有关的内存CPU 等信息的收集。zabbix 监控原理zabbix agent 安装在被监控的主机上zabbix agent 负责定期收集客户端本地各项数据并发送至 zabbix server 端zabbix server 收到数据后 将数据存储到数据库中用户基于 Zabbix Web 可以看到数据在前端展现图像。当 zabbix 监控某个具体的项目 该项目会设置一个触发器阈值 当被监控的指标超过该触发器设定的阈值会进行一些必要的动作动作包括发送信息邮件、微信、短信、发送命令shell 命令、reboot、restart、 install 等。1.2 zabbix 6.0特性【注】从zabbix6.0开始支持对于K8S地监控Zabbix 6.0 新特性1、Zabbix server高可用防止硬件故障或计划维护期的停机•原生选择加入HA群集配置•定义一个或多个备用节点•实时监控Zabbix server群集节点的状态•不需要外部工具即可将Zabbix server配置为HA群集模式2、Zabbix 6.0 LTS新增Kubernetes监控功能可以在Kubernetes系统从多个维度采集指标•Kubernetes节点和pods的自动发现和监控•无代理方式采集Kubernetes pods和节点的信息•获取Kubernetes节点主机高水平信息1.3 功能组件●Zabbix Serverzabbix 服务端守护进程是 Zabbix 软件的核心组件Zabbix Agent 向其报告可用性、系统完整性信息和统计信息。Zabbix Server 也是存储所有配置信息、统计信息和操作信息的核心存储库。Zabbix Server 也是 Zabbix 监控系统的告警中心。在监控的系统中出现任何异常将发出通知给管理员。基本的 Zabbix Server 的功能分解成为三个不同的组件。他们是Zabbix server、Web 前端、数据库。Zabbix 的所有配置信息都存储在 Server 和 Web 前端进行交互的数据库中。例如当你通过 Web 前端或者API新增一个监控项时 它会被添加到数据库的监控项表里。然后Zabbix server 以每分钟一次的频率查询监控项表中的有效项接着将它存储在 Zabbix server 中的缓存里。 这就是为什么 Zabbix 前端所做的任何更改需要花费两分钟左右才能显示在最新的数据段的原因。●数据库所有配置信息以及 Zabbix 采集到的数据都被持久存储在数据库中。可以支持 MySQL、PostgreSQL、Oracle、DB2、TimescaleDB 等多种数据库。●Web 界面Web 界面是 Zabbix Server 的一部分用于实现展示和配置的界面。通常但不一定和 Zabbix server 运行在同一台物理机器上。基于 Apache/Nginx PHP 实现早期只支持 LAMP 架构从 Zabbix5.0 开始支持 LNMP 。●Zabbix Agent客户端守护进程部署在被监控目标上用于主动监控本地资源和应用程序并将收集的数据发送给 Zabbix Server。从 Zabbix5.0 开始支技 Zabbix Agent2 。●Zabbix Proxyzabbix 分布式代理守护进程可以代替 Zabbix Server 采集性能和可用性数据。Zabbix Proxy 在 Zabbix 的部署是可选部分。Zabbix Proxy 的部署可以很好的分担单个 Zabbix Server 的负载。通常监控大于 500 台主机时使用需要进行分布式监控架构部署。●Java GatewayZabbix 要监控 Tomcat 服务或其它 JAVA 程序比例 Elasticsearch、ZooKeeper需要使用 Java Gateway 做为代理才能从 JAVA 程序中获取数据。1.4 zabbix工作过程1.5 总结zabbix适用于监控传统地业务架构监控物理服务器网络设备等等Prometheus适用于监控K8Sdocker微服务架构在云原生环境中表现优异架构 cs架构模型服务端组件zabbix server: zabbix 服务端进程用于接收客户端发来的监控数据还负责配置和管理zabbix的应用程序也是监控系统和告警中心也可以通过监控项告警触发配置实现告警zabbix 数据库持久化存储zabbix的配置信息和监控数据支持关系型数据库MySQL、pgsql、 Oracle 等数据库也支持时序数据库zabbix web服务端配置管理界面和监控端数据的UI界面的展示支持LNMP LAMP架构客户端zabbix agent部署在被监控的服务器上面用于采集监控数据并发送给zabbix server 数据采集有主动模式和被动模式一般情况下是被动模式zabbix proxy zabbix代理端进程部署在zabbixserver和agent之间,用于代替zabbix server接受数据从而减少zabbix server的负载压力zabbix java gateway 用于获取从通过在java程序上暴露的jmx远程接口从这远程采集数据对java应用程序的远程监控工作原理zabbix通过zabbix、agent 、java 、gateway、SNMP 等方式定期采集监控目标的监控数据并发送给zabbix server ,zabbix server 接收到数据后会存储在zabbix数据库中运维管理可以通过zabbix web 接入zabbix数据库在浏览网页中查看相关的监控数据图像