分布式系统监视zabbix讲解七之分布式监控
分布式监控
概述
Zabbix通过Zabbix proxy为IT基础设施提供有效和可用的分布式监控
代理(proxy)可用于代替Zabbix server本地收集数据,然后将数据报告给服务器。
Proxy 特征
当选择使用/不使用proxy时,必须考虑几个注意事项。
| Proxy | |
|---|---|
| 轻量级(Lightweight) | Yes |
| 图形界面(GUI) | No |
| 独立工作(Works independently) | Yes |
| 易于维护(Easy maintenance) | Yes |
| 自动生成数据库(Automatic DB creation)1 | Yes |
| 本地管理(Local administration) | No |
| 准备嵌入式硬件 (Ready for embedded hardware) | Yes |
| 单向TCP连接(One way TCP connections) | Yes |
| 集中配置(Centralised configuration) | Yes |
| 生成通知(Generates notifications) | No |
代理
概述
zabbix proxy 可以代替 zabbix server 收集性能和可用性数据,然后把数据汇报给 zabbix server,并且在一定程度上分担了zabbix server 的压力.
此外,当所有agents和proxies报告给一个Zabbix server并且所有数据都集中收集时,使用proxy是实现集中式和分布式监控的最简单方法。
zabbix proxy 使用场景:
- 监控远程区域设备
- 监控本地网络不稳定区域
- 当 zabbix 监控上千设备时,使用它来减轻 server 的压力
- 简化分布式监控的维护

zabbix proxy 仅仅需要一条 tcp 连接到 zabbix server,所以防火墙上仅仅需要加上一条规则即可。
proxy 收集到数据之后,首先将数据缓存在本地,然后在一定得时间之后传递给 zabbix server,这样就不会因为服务器的任何临时通信问题而丢失数据。这个时间由proxy配置文件中参数 ProxyLocalBuffer 和 ProxyOfflineBuffer 决定。
zabbix proxy 是一个数据收集器,它不计算触发器、不处理事件、不发送报警。有关proxy功能的概述,如下表:
| 功能 | proxy支持(yes/no) | |
|---|---|---|
| 项目(Items) | ||
| Zabbix agent checks | Yes | |
| Zabbix agent checks (active) | Yes 1 | |
| Simple checks | Yes | |
| Trapper items | Yes | |
| SNMP checks | Yes | |
| SNMP traps | Yes | |
| IPMI checks | Yes | |
| JMX checks | Yes | |
| 日志文件监控(Log file monitoring) | Yes | |
| 内部检查(Internal checks) | Yes | |
| SSH checks | Yes | |
| Telnet checks | Yes | |
| 外部检查(External checks) | Yes | |
| 内置web监控(Built-in web monitoring) | Yes | |
| 网络发现(Network discovery) | Yes | |
| 自动发现(Low-level discovery) | Yes | |
| 触发器计算(Calculating triggers) | No | |
| 处理事件(Processing events) | No | |
| 发送报警(Sending alerts) | No | |
| 远程命令(Remote commands) | No | |
配置
一旦安装并配置了一个proxy,我们便可以在zabbix管理站点配置它了。
添加 proxies
要在Zabbix前端配置代理:
- 转到:管理→agent代理程序
- 单击创建代理

| 参数 | 描述 |
|---|---|
| agent代理程序名称 | proxy名称。它必须与proxy配置文件中的Hostname参数中的名称相同。 |
| 代理模式(Proxy mode) | 选择proxy模式 Active – the proxy will connect to the Zabbix server and request configuration data Passive – Zabbix server connects to the proxy Note that without encrypted communications (sensitive) proxy configuration data may become available to parties having access to the Zabbix server trapper port when using an active proxy. This is possible because anyone may pretend to be an active proxy and request configuration data if authentication does not take place. |
| 系统代理程序模式 | 选择proxy模式 主动式 – proxy将连接到Zabbix server并请求配置数据 被动式 – Zabbix server连接到代理proxy 注意,当使用active proxy,未加密通信(敏感)proxy配置数据可用于访问Zabbix server trapper端口。如果不进行身份验证,任何人都可以伪装成active proxy并请求配置数据。 |
| Hosts | Add hosts to be monitored by the proxy. Hosts already monitored by another proxy are greyed out in the Other hosts selection. |
| 主机 | 添加要由proxy监视的主机。 被另一个proxy监视的主机在其他主机选项中显示为灰色。 |
| Description | Enter the proxy description. |
| 描述 | 输入proxy描述。 |
该 加密选项卡允许你与proxy的加密连接。
| 参数 | 描述 |
|---|---|
| 连接代理 | 服务器如何连接到被动代理:非加密(默认),共享秘钥(PSK)或证书。 |
| 从代理连接 | 从active proxy中选择允许的连接类型。可以同时选择几种连接类型(用于测试和切换到其他连接类型)。默认为“无加密”。 |
| 发行者 | 允许颁发证书。证书首先通过CA(认证机构)验证。如果CA有效,则由CA签名,这时可以使用发行者字段来进一步限制允许的CA。该字段是可选的,如果你的Zabbix安装使用多个CA的证书,则使用该字段。 |
| 主体 | 允许的证书。证书首先通过CA验证。如果它有效,由CA签名,这时主体字段可以用于仅允许一个主体字符串值。如果此字段为空,则接受CA签名的任何有效证书。 |
| 共享密钥一致性 | 共享密钥身份字符串 |
| 共享密钥(PSK) | 共享密钥(16进制)。如果Zabbix使用mbed TLS(PolarSSL)库,最大长度为64位十六进制(32字节PSK);如果Zabbix使用GnuTLS或OpenSSL库,最大长度为512位十六进制数(256字节PSK)。示例:1f87b595725ac58dd977beef14b97461a7c1045b9a1c963065002c5473194952 |
实现分布式监控
三类节点软件安装
1. 监控节点
zabbix-sever-mysql
zabbix-web-mysql
db
2. 被监控节点
zabbix-agent
3. 代理节点
zabbix-proxy-mysql
db
1.准备工作(略)
1. 关闭selinux
2. 关闭iptables
3. 时间同步
4. 互相可解析主机名(一定要保证客户端可以解析代理服务器端的主机名)
2.监控节点安装配置(10.220.5.137)
略。大家可以在我的第一篇博客中详细看下,监控节点如何安装《分布式系统监视zabbix讲解一之zabbix安装–技术流ken》
3.配置代理节点(10.220.5.138)
1.安装
[root@ken ~]# yum install zabbix-proxy-mysql mariadb-server -y
2.创建表和数据库用户
mysql> create database zabbix;
Query OK, 1 row affected (0.00 sec) mysql> grant all on *.* to zabbix@'localhost' identified by '123';
Query OK, 0 rows affected, 1 warning (0.05 sec)
3.准备表和数据
[root@proxy ~]# cp /usr/share/doc/zabbix-proxy-mysql-3.0.22/schema.sql.gz ./
[root@proxy ~]# gunzip schema.sql.gz
4.把表和数据导入到数据库
mysql> source /root/schema.sql
5.配置proxy的配置文件
配置文件内容很长,这里列出来几行须要修改的部分,你也可以根据你自己的情况来修改。

[root@proxy ~]# vim /etc/zabbix/zabbix_proxy.conf
ProxyMode=0 #更改为主动模式
Server=10.220.5.137 #指定监控节点
ListenPort=10051 #开启监控端口
Hostname=proxy #这里要写代理服务器的主机名,并且保证各个节点可以解析/etc/hosts
DBHost=localhost #数据库地址
DBName=zabbix #数据库名字
DBUser=zabbix #数据库用户
DBPassword=123 #用户zabbix的密码

6.启动zabbix-proxy
[root@ken ~]# systemctl restart zabbix-proxy
四.配置zabbix-agent客户端(10.220.5.139)
1.下载zabbix-agent客户端
[root@ken ~]# yum install zabbix-agent -y
2.配置zabbix-agent客户端

[root@ken ~]# vim /etc/zabbix/zabbix_agentd.conf
86 ### Option: Server
87 # List of comma delimited IP addresses (or hostnames) of Zabbix servers and Zabbix proxies.
88 # Incoming connections will be accepted only from the hosts listed here.
89 # If IPv6 support is enabled then '127.0.0.1', '::127.0.0.1', '::ffff:127.0.0.1' are treated equally.
90 #
91 # Mandatory: yes, if StartAgents is not explicitly set to 0
92 # Default:
93 # Server=
94
95 Server=10.220.5.138 #ip地址指向代理服务器端
96
97 ### Option: ListenPort
98 # Agent will listen on this port for connections from the server.
99 #
100 # Mandatory: no
101 # Range: 1024-32767
102 # Default:
103 # ListenPort=10050
...
133 # Default:
134 # ServerActive=
135
136 ServerActive=10.220.5.138 #指向代理服务器
137
138 ### Option: Hostname
139 # Unique, case sensitive hostname.140 # Required for active checks and must match hostname as configured on th e server.
141 # Value is acquired from HostnameItem if undefined.
142 #
143 # Mandatory: no
144 # Default:
145 Hostname=proxy #这里的hostname是指在web页面的zabbix创建的那个代理名称,一定要保持一致
146
147 #Hostname=Zabbix server

客户端只要修改这三处即可。
3.重启zabbix-proxy客户端
[root@ken ~]# systemctl restart zabbix-agent
五.在zabbix网页端添加代理服务器
第一步:创建主机
首先需要把主机,即添加10.220.5.139被监控节点,名字可以随便写,但是后面的代理名字必须和代理服务器的主机名保持一致。


第二步:创建proxy.点击administration>proxies,名字必须和代理服务器的主机名保持一致。


第三步:查看。monitoring>latest data >select(你的主机)


分布式系统监视zabbix讲解七之分布式监控的更多相关文章
- 分布式系统监视zabbix讲解七之分布式监控--技术流ken
分布式监控 概述 Zabbix通过Zabbix proxy为IT基础设施提供有效和可用的分布式监控 代理(proxy)可用于代替Zabbix server本地收集数据,然后将数据报告给服务器. Pro ...
- 分布式系统监视zabbix讲解六之自定义监控项--技术流ken
宏 概述 Zabbix支持许多在多种情况下使用宏.宏是一个变量,由如下特殊语法标识: {MACRO} 根据在上下文中, 宏解析为一个特殊的值. 有效地使用宏可以节省时间,并使Zabbix变地更加高效. ...
- 分布式系统监视zabbix讲解六之自定义监控项
概述 Zabbix支持许多在多种情况下使用宏.宏是一个变量,由如下特殊语法标识: {MACRO} 根据在上下文中, 宏解析为一个特殊的值. 有效地使用宏可以节省时间,并使Zabbix变地更加高效. 在 ...
- 分布式系统监视zabbix讲解五之web监控--技术流ken
Web 监控 概况 你可以使用 Zabbix 检查几个网站可用性方面. 如果要使用 Web 检测功能,必须在 编译Zabbix 的时候加入 cURL(libcurl) 的支持. 要使用 Web 监控, ...
- 分布式系统监视zabbix讲解五之web监控
Web 监控 概况 你可以使用 Zabbix 检查几个网站可用性方面. 如果要使用 Web 检测功能,必须在 编译Zabbix 的时候加入 cURL(libcurl) 的支持. 要使用 Web 监控, ...
- 分布式系统监视zabbix讲解二之邮件报警通知--技术流ken
概述 在上一篇博客<分布式系统监视zabbix讲解一技术流ken>中已经详细讲解了如何安装zabbix,本篇博客将详细讲解如何使用zabbix监控另外一台主机,并实现email报警通知机制 ...
- 分布式系统监视zabbix讲解二之邮件报警通知
概述 在上一篇博客<分布式系统监视zabbix讲解一技术流ken>中已经详细讲解了如何安装zabbix,本篇博客将详细讲解如何使用zabbix监控另外一台主机,并实现email报警通知机制 ...
- 分布式系统监视zabbix讲解一之zabbix安装--技术流ken
zabbix概述 Zabbix是什么 Zabbix 是由Alexei Vladishev创建,目前由Zabbix SIA在持续开发和支持. Zabbix 是一个企业级的分布式开源监控方案. Zabbi ...
- 分布式系统监视zabbix讲解九之使用snmp监控windows--技术流ken
前言 使用zabbix监控windows主要有两种方法,一种是在windows端安装zabbix-agent客户端工具,安装麻烦.另外一种是使用snmp协议,配置简单快捷.两种配置都可以实现同样的效果 ...
随机推荐
- Html5与CSS3(选择器)
<!-- 作者:offline 时间:2018-03-21 描述:1.全选择器 *{属性1:属性值2:属性2:属性值2:...:} 2.元素(标签)选择器 标签名{属性1:属性值2:属性2:属性 ...
- JavaScript学习系列博客_20_JavaScript 作用域
作用域 - 作用域指一个变量的作用的范围 - 在JS中一共有两种作用域 1.全局作用域 - 直接编写在script标签中的JS代码,都在全局作用域- 全局作用域在页面打开时创建,在页面关闭时销毁 - ...
- J20航模遥控器开源项目系列教程(二)使用说明 | 遥控器制作完成了,怎么用?
我们的开源宗旨:自由 协调 开放 合作 共享 拥抱开源,丰富国内开源生态,开展多人运动,欢迎加入我们哈~ 和一群志同道合的人,做自己所热爱的事! 项目开源地址:https://github.com/C ...
- php使用curl来获取远程图片
本文章来介绍php使用curl来获取远程图片实现方法,有需要了解采集远程图片的朋友不防进入参考. curl要求php环境支持才行. 可以运行phpinfo()函数是否支持,一般要将php.ini中;e ...
- .NetCore使用Redis,StackExchange.Redis队列,发布与订阅,分布式锁的简单使用
环境:之前一直是使用serverStack.Redis的客服端,今天来使用一下StackExchange.Redis(个人感觉更加的人性化一些,也是免费的,性能也不会差太多),版本为StackExch ...
- Hadoop上小文件如何存储?
Block是文件块,HDFS中是以Block为单位进行文件的管理的,一个文件可能有多个块,每个块默认是3个副本,这些块分别存储在不同机器上.块与文件之前的映射关系会定时上报Namenode.HDFS中 ...
- Charles 断点修改Response
前言: 我们可以通过map功能进行重定向,但如果同一个域名进行的是不同请求与返回.此时map在这里就不适用了. 我们可以通关对某一请求进行断点,在进行修改请求或者返回.这样就可以满足我们的需求了. 一 ...
- Go语言从入门到高薪之路(一)-- 初识与安装
为什么要学习Go语言? Go语言又称Golang,它是21世纪的编程语言,学好了就能拿高薪,拿了高薪就能实力装逼,有了实力就能泡妹子...(我就问你吊不吊,想不想学?) Go语言有什么特点和优势? G ...
- vs使用fscanf和fprintf错误警告处理
严重性代码说明项目文件行 禁止显示状态错误 C4996 fopen('fscanf'.strcmp):This function or variable may be unsafe. 最全解决办法(转 ...
- .NET Core3.1 Dotnetty实战第二章
一.概要 在上一篇文章讲到Dotnetty的基本认识,本文这次会讲解dotnetty非常核心的模块是属于比较硬核的干货了,然后继续往下讲解如何根据自己的需求或者自己的喜好去配置Dotnetty而不是生 ...