目录
一、Zabbix简介
什么是Zabbix
Zabbix功能
Zabbix架构
Zabbix数据流
二、Zabbix的安装
首先保证虚拟机可以连接网络
安装yum-utils
下载rpm安装包
更改成阿里的下载路径,这样下载更快。
安装server和agent
安装前端
安装数据库
导入数据库
为Zabbix server 配置数据库
为Zabbix前端配置PHP
启动服务,设置开机自起
三、Zabbix添加agent
server2,server3安装zabbix-agent
手动添加主机server2
自动发现---> 添加server3
自动注册
官网:https://www.zabbix.com/cn/
Zabbix 是一种企业级的分布式开源监控解决方案,是一种高度集成的网络监控解决方案,在单一的软件包中提供了多种功能。
Zabbix 是一款能够监控众多网络参数和服务器的健康度和完整性的软件。Zabbix 使用灵活的通知机制,允许用户为几乎任何事件配置基于邮件的警报。这样可以快速相应服务器问题。Zabbix 基于存储的数据提供出色的报告和数据可视化。这些功能使得 Zabbix 成为容量规划的理想选择。
Zabbix 支持轮询和被动捕获。所有的 Zabbix 报告、统计信息和配置参数都可以通过基于 Web 的前端页面进行访问。基于 Web 的前端页面确保您的网络状态和服务器健康状况可以从任何地方进行评估。在经过适当的配置后,Zabbix 可以在监控 IT 基础设施方面发挥重要作用。无论是对于拥有少量服务器的小型组织,还是拥有大量服务器的大型公司而言,同样适用。
Zabbix 是一种高度集成的网络监控解决方案,在单一的软件包中提供了多种功能。
数据采集
- 可用性和性能采集;
- 支持 SNMP(包括主动轮询和被动捕获)、IPMI、JMX、VMware 监控;
- 自定义检查;
- 按照自定义的时间间隔采集需要的数据;
- 通过 Server/Proxy 和 Agents 来执行数据采集。
灵活的阈值定义
- 您可以定义非常灵活的告警阈值,称之为触发器,触发器从后端数据库获得参考值。
高度可配置化的告警
- 可以根据递增计划、接收者、媒介类型自定义发送告警通知;
- 使用宏变量可以使告警通知变得更加高效有益;
- 自动动作包含远程命令。
实时图形
- 使用内置图形功能可实以将监控项绘制成图形。
Web 监控功能
- Zabbix 可以追踪模拟鼠标在 Web 网站上的点击操作,来检查 Web 网站的功能和响应时间。
丰富的可视化选项
- 能够创建可以将多个监控项组合到单个视图中的自定义图形;
- 网络拓扑图;
- 以仪表盘样式展示自定义聚合图形和幻灯片演示;
- 报表;
- 监控资源的高层次(业务)视图。
历史数据存储
- 存储在数据库中的数据;
- 可配置的历史数据;
- 内置数据管理机制(housekeeping)。
配置简单
- 将被监控设备添加为主机;
- 主机一旦添加到数据库中,就会采集主机数据用于监控;
- 将模板用于监控设备。
套用模板
- 在模板中分组检查;
- 模板可以关联其他模板,获得继承。
网络发现
- 自动发现网络设备;
- Zabbix Agent 发现设备后自动注册;
- 自动发现文件系统、网络接口和 SNMP OIDs 值。
快捷的 Web 界面
- 基于 PHP 的 Web 前端;
- 可以从任何地方访问;
- 您可以定制自己的操作方式;
- 审计日志。
Zabbix API
- Zabbix API 为 Zabbix 提供可编程接口,用于批量操作、第三方软件集成和其他用途。
权限管理系统
- 安全的用户身份验证;
- 将特定用户限制于访问特定的视图。
功能强大且易于扩展的 Zabbix Agent
- 部署于被监控对象上;
- 完美支持 Linux 和 Windows ;
二进制守护进程
- 为了更好的性能和更少的内存占用,采用 C 语言编写;
- 便于移植。
适应更复杂的环境
- 使用 Zabbix Proxy 代理,可以轻松实现分布式远程监控。
Zabbix 由几个主要的功能组件组成,其职责如下所示。
Server
Zabbix server 是 Zabbix agent 向其报告可用性、系统完整性信息和统计信息的核心组件。是存储所有配置信息、统计信息和操作信息的核心存储库。
数据库
所有配置信息以及 Zabbix 收集到的数据都被存储在数据库中。
Web 界面
为了从任何地方和任何平台轻松访问 Zabbix ,我们提供了基于 web 的界面。该界面是 Zabbix server 的一部分,通常(但不一定)和 Zabbix server 运行在同一台物理机器上。
Proxy
Zabbix proxy 可以替 Zabbix server 收集性能和可用性数据。Zabbix proxy 是 Zabbix 环境部署的可选部分;然而,它对于单个 Zabbix server 负载的分担是非常有益的。
Agent
Zabbix agents 部署在被监控目标上,用于主动监控本地资源和应用程序,并将收集的数据发送给 Zabbix server。
Zabbix 内部的整体数据流。首先,为了创建一个采集数据的监控项,您就必须先创建主机。其次,必须有一个监控项来创建触发器。最后,您必须有一个触发器来创建一个动作,这几个点构成了一个完整的数据流。因此,如果您想要收到 CPU load it too high on Server X 的告警,您必须首先为 Server X 创建一个主机条目,其次创建一个用于监视其 CPU 的监控项,最后创建一个触发器,用来触发 CPU is too high 这个动作,并将其发送到您的邮箱里。虽然这些步骤看起来很繁琐,但是使用模板的话,其实并不复杂。也正是由于这种设计,使得 Zabbix 的配置变得更加灵活易用。
会带有官方的yum源,速度会比较慢,
由于我们是红帽系统是没有官网步骤c这个包的,CentOS系统是自带的
所以首先从阿里云下载下面两个rpm包
下载下来后安装,由于具有依赖性,两个同时安装。
前端默认仓库是没有激活的,需要将文件中的enabled=1
上面下载的包是用来解决我们下面安装前端时候大量依赖性的。
前端要求是php7.2
而我们自带的是5.4.16所以不满足要求,所以用上面的centeos的源解决这块的依赖性。
从官网下载不用编译的5.7的数据库包,并解压。
开启数据库,并设置开机自起,并在日志中查看密码; #修改密码【大小写+特殊字符和数字】
开始一旦忘记密码,可关闭数据库后,清空数据库文件
重新执行上述初始化过程。
该过程很久,耐心等待,不要ctrl+c退出
导入以后进入数据库查看
登录页面用户默认:admin;密码:zabbix
语言修改:
在2、3上配置yum源 ,将server1的repo文件拷贝过来
在server2、3中修改reop文件,并安装zabbix-agent
修改配置文件:117行server=172.25.0.1,158行serveractive是172.25.0.1,169行,主机名是自己主机名,最后进行地址解析,最后设置开机自起。注意防火墙一定要关闭。
配置主机——创建主机——主机名——群组Linux servers——客户端ip——端口10050——添加
此时还没有监控项
点击模板,选择模板,点击更新
刷新等待zax亮起。
配置——动作——Tirgger actions——Discovery actions——激活——已启用
配置——自动发现——localhost ——修改ip范围——勾选启用——更新(注意此处的ip与我前文不符,当时没有截取,从他处借来)
该方法适合大批量的通用配置的添加。
删除server3,然后实验自动注册。
server端首先将已启用的自动发现停止。动作也停止掉。
配置——动作——Tirgger actions——自动注册
点击右上角的创建动作 ,名称auto_red可以随便起,选择触发条件
切换到操作再次点击添加,此处可以添加多个
回到动作,点击添加。
之后停止再打开server3的agent服务,直接重启不可以。
刷新成功。