zabbix 是一个基于 WEB 界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。zabbix 能监视各种网络参数,保证服务器系统的安全运营;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。
Zabbix 的运行架构如下图所示:
(一)zabbix 由以下几个组件部分构成:
1) Zabbix Server
负责接收 agent 发送的报告信息的核心组件,所有配置,统计数据及操作数据均由其组织进行;
2) Database Storage
专用于存储所有配置信息,以及由 zabbix 收集的数据;
3) Web interface
zabbix 的 GUI 接口,通常与 Server 运行在同一台主机上;
4) Proxy
可选组件,常用于分布监控环境中,代理 Server 收集部分被监控端的监控数据
并统一发往 Server 端;
5) Agent
部署在被监控主机上,负责收集本地数据并发往 Server 端或 Proxy 端
注:zabbix node 也是 zabbix server 的一种 。
2 进程
默认情况下zabbix包含5个程序: zabbix_agentd、 zabbix_get、 zabbix_proxy、 zabbix_sender、zabbix_server,另外一个 zabbix_java_gateway 是可选,这个需要另外安装。
他们各自的作用:
zabbix_agentd
客户端守护进程,此进程收集客户端数据,例如 cpu 负载、内存、硬盘使用情况等。
zabbix_get
zabbix 工具,单独使用的命令,通常在 server 或者proxy端执行获取远程客户端信息的命令。 通常用户排错。 例如在server端获取不到客户端的内存数据, 我们可以使用zabbix_get获取客户端的内容的方式来做故障排查。
zabbix_sender
zabbix 工具,用于发送数据给 server 或者proxy,通常用于耗时比较长的检查。很多检查非常耗时间,导致 zabbix 超时。于是我们在脚本执行完毕之后,使用 sender 主动提交数据。
zabbix_server
zabbix 服务端守护进程。zabbix_agentd、zabbix_get、zabbix_sender、zabbix_proxy、zabbix_java_gateway 的数据最终都是提交到 server
备注:当然不是数据都是主动提交给 zabbix_server,也有的是 server 主动去取数据。
zabbix_proxy
zabbix 代理守护进程。功能类似server,唯一不同的是它只是一个中转站,它需要把收集到的数据提交/被提交到 server 里。
zabbix_java_gateway
zabbix2.0 之后引入的一个功能。顾名思义:Java 网关,类似 agentd,但是只用于 Java方面。需要特别注意的是,它只能主动去获取数据,而不能被动获取数据。 它的数据最终会给到server或者proxy。
3 zabbix监控环境中相关术语
主机(host) :要监控的网络设备,可由 IP 或 DNS 名称指定;
主机组(host group):主机的逻辑容器,可以包含主机和模板,但同一个组织内的主机和模板不能互相链接;主机组通常在给用户或用户组指派监控权限时使用;
监控项(item) :一个特定监控指标的相关的数据;这些数据来自于被监控对象;item是 zabbix 进行数据收集的核心,相对某个监控对象,每个 item 都由"key"标识;
触发器(trigger) :一个表达式,用于评估某监控对象的特定 item 内接收到的数据是否在合理范围内,也就是阈值;接收的数据量大于阈值时,触发器状态将从"OK"转变为"Problem",当数据再次恢复到合理范围,又转变为"OK";
事件(event) :触发一个值得关注的事情,比如触发器状态转变,新的 agent 或重新上
线的 agent 的自动注册等;
动作(action) :指对于特定事件事先定义的处理方法,如发送通知,何时执行操作;
报警媒介类型(media) :发送通知的手段或者通道,如 Email、Jabber 或者 SMS 等;
模板 (template) :用于快速定义被监控主机的预设条目集合, 通常包含了 item、 trigger、graph、 screen、 application 以及 low-level discovery rule;模板可以直接链接至某个主机;
前端(frontend) :Zabbix 的 web 接口
二,ZabbixServer的安装
1 搭建自定义yum仓库并安装支持包
如果下一步出现问题,请注释掉yum配置文件里的本地光盘源
2 编译安装LNMP环境
安装nginx 创建nginx配置文件模版
Agent端安装Nginx,可将客户端的nginx的配置文件发送一份到Agent端
安装mysql
安装libmcrypt
安装GD
安装PHP
创建php配置文件
修改php配置文件php.ini
创建php-fpm配置文件
修改php-fpm.conf配置文件
3 安装zabbix server端
编译安装zabbix server
由于zabbix启动脚本路径默认指向的是/usr/local/sbin路径,因此,需要提前建立软连接
配置zabbix的mysql环境
Zabbix server 和mysql安装到一台服务器上,首先需要手动创建zabbix数据库
如下数据的导入顺序不可以错
4 安装Zabbix web GUI
- Zabbix web是php代码编写的,因此需要有php环境,前面已经安装好了lnmp,因此可以直接使用。
- 默认的nginx安装的根目录为/usr/local/nginx/html,因此,只需要Zabbix web的代码放到此目录即可。
- Zabbix web的代码在Zabbix源码包中的frontends/php目录下,将这个php目录拷贝到/usr/local/nginx/html/目录下并改名zabbix即可完成Zabbix web端的安装。
- 在浏览器输入http://IP/zabbix,然后会检查zabbix web运行环境是否满足,并提供连接数据库的相关信息即可,最后将连接数据库相关信息都存入文件zabbix/conf/zabbix.conf.php中,这样就可以登录zabbix的web平台了。
- 默认的zabbix平台登录用户名为Admin,密码为zabbix。
复制zabbix web目录到nginx web根目录下
启动nginx服务及php-fpm
登录web根据提示生成zabbix.conf.php配置文件
起初并没有zabbix.conf.php配置文件,我们可以选择自动生成配置文件
在浏览器里输入http://IP/zabbix,配置zabbix数据库环境,如下图所示:
执行如上图所示的步骤生成zabbix.conf.php配置文件
里面记录的信息就是我们刚刚的操作
提示:
除了通过web界面的方式生成zabbix.conf.php文件外,我们也可以利用zabbix.conf.php.example的模版文件直接修改成我们需要的配置文件。
登录zabbix web
设置zabbix中文模式
修改密码
三,zabbix server的配置
zabbix_server.conf配置
通过源码安装方式将zabbix安装到/usr/local/zabbix下面,zabbix server的配置文件为/usr/local/zabbix/etc/zabbix_server.conf,需要修改的内容为如下:
12 ListenPort=10051 #zabbix server监听端口
38 LogFile=/tmp/zabbix_server.log #zabbix server日志路径
87 DBName=zabbix #zabbix server连接MySQL数据库的数据库名
103 DBUser=zabbix #zabbix server连接MySQL数据库的用户名
111 DBPassword=123123 #zabbix server连接MySQL数据库的密码
118 DBSocket=/tmp/mysql.sock #MySQL的实例文件位置
136 StartPollers=5 #用于设置zabbix server服务启动时启动Pollers(主动收集数据进程)的数量,数量越多,则服务端吞吐能力越强,同时对系统资源消耗越大
165 StartTrappers=10 #用于设置zabbix server服务启动时启动Trappers(负责处理Agentd推送过来的数据的进程)的数量。Agentd为主动模式时,zabbix server需要设置这个值大一些。
181 StartDiscoverers=10 #用于设置zabbix server服务启动时启动Discoverers进程的数量,如果zabbix监控报Discoverers进程忙时,需要提高该值。
297 ListenIP=0.0.0.0 #zabbix server启动的监听端口对哪些ip开放,Agentd为主动模式时,这个值建议设置为0.0.0.0
447 AlertScriptsPath=/usr/local/zabbix/share/zabbix/alertscripts #zabbix server运行脚本存放目录,一些供zabbix server使用的脚本,都可以放在这里。
将zabbix_server.conf文件内容修改成如下所示
添加相关服务和端口到系统配置文件
编辑/etc/services文件,在最后添加以下代码:
其中,10051是zabbix server的监听端口,10050是zabbix agent的监听端口。
添加管理维护脚本
启动zabbix_server端进程
四,zabbix_agent的安装与配置
zabbix agent端的安装建议采用rpm包方式安装,可从http://repo.zabbix.com/zabbix/3.2/下载zabbix的agent端rpm包,版本与zabbix server端保持一致,安装如下:
安装完成后,zabbix agent端已经安装完成了,zabbix agent端的配置目录位于/etc/zabbix下,可在此目录进行配置文件的修改。
特别提示:
- zabbix server的源码包本身就包含了zabbix server端和zabbix agent端,因此,zabbix服务器端无需再安装zabbix agent的rpm包。
- 然而zabbix agent的rpm包是为了方便在服务器上进行快速安装而设计的快捷安装包。
- 因此为了统一,监控端和被监控端的zabbix agent我们都用rpm的安装方式
修改zabbix agent端的配置文件
需要修改的内容如下所示
将内容修改为如下所示:
启动zabbix_agent端进程
在监控端和被监控端都进行如上所述的zabbix agent端的安装。
五,测试zabbix server监控
-s 是指定zabbix agent端的IP地址
-p 是指定zabbix agent端的监听端口
-k 是监控项,即item
如果有输出结果,表面zabbix server可以从zabbix agent获取数据,配置成功。
六,Zabbix的web操作入门
Zabbix Web 操作概述
Zabbix首页仪表提示面板
- 常用的图形:可以根据自己喜好,添加按主机按监控项添加快捷的查看链接
- 常用的聚合图形:可以将多个监控图形的曲线合并显示
- 常用的拓扑图:集群的架构图
- 主机状态:被监控的主机的实时状态
- Web检测:发一个http请求,看看web是否能正常访问
- 系统状态:监控端zabbix server服务器的状态
- 最近20个问题:最后发生的20个告警信息
- Zabbix状态:zabbix server监控的详细汇总信息
2 自定义首页面板
调整后,如下所示:
3 追加常用的监控图形
4设置报警提示声音
5 获取最新的zabbix共享模版
自定义被监控的服务器
自定义一个主机组
在生产环境时,主机组的名字一定要用英文,不然,当zabbix进行二次开发的时候,中文名称都是乱码。
自定义一个主机
在生产环境中主机的名字一定要是英文,并且务必和真实主机的主机名一致,且必须归类加入到主机组中。不然zabbix在进行二次开发的时候会非常麻烦(需要建立类似索引形式的东西去关联真实服务器)
自定义一个监控项
进行监控项的后台定义
现在假如我们要定义一个获取nginx连接数的监控项,那么我们先得去尝试能够获取这个值。在之前的nginx配置文件里已经加入了status模块的获取
(1)登录网页获取这个信息
(2)我们尝试通过命令获取这个信息
(3)在zabbix agent配置文件里定义这个监控项
Include=/etc/zabbix/zabbix_agentd.d/ #我们发现zabbix_agentd.d目录已经默认被include进入了主配置文件。
由于zabbix_agentd.conf配置文件默认导入了所有zabbix_agentd.d目录下的内容,因此我们可以将监控项定义到zabbix_agentd.d目录下。
通过观察agent提供给我们的监控定义模板文件发现,监控的定义分为两部分(1)监控项的名称 (2)监控项的信息获取命令
(4)参考模版,自己定义监控项的获取命令
(5)自定义监控项,等于改变了配置文件,自然需要重启zabbix_agentd
(6)在zabbix server端测试获取自定义的监控项信息
zabbix_get -s 10.1.1.158 -p 10050 -k "nginx.active"
至此zabbix自定义监控项的后台定义全部完成。
进行监控项的前台定义
(1)点选一个被监控的主机
(2)进入监控项创建模版
(4)创建完成的监控项
监控项创建完成以后,在zabbix server这个主机里就出现这个新定义的监控项了。
自定义一个监控项的图形
(1)点选一个被监控的主机
(2)进入图形创建模版
(3)查看图形绘图
(4)关于图形的各种显示效果
正常图形:
层积图形
Pie图形
爆发的图形
自定义一个聚合图形
(1)创建一个聚合图形
(2)编辑聚合图形
(3)选择展示图形
(4)将聚合图形添加到zabbix web首页面板