Zabbix-(七)分布式监控

一.前言

Zabbix提供了一套分布式监控的方案,即使用Zabbix Proxy,本文记录使用Zabbix Proxy进行分布式监控。

官方所述Proxy的使用场景如下:

  • 监控远程区域设备
  • 监控本地网络不稳定区域
  • 当 zabbix 监控上千设备时,使用它来减轻 server 的压力
  • 简化分布式监控的维护

准备

  • Zabbix Server 4.4 (ip 192.168.152.140)
  • Centos 7, 用于安装 Zabbix Proxy (ip 192.168.152.144) 以下简称Proxy-Server
  • mysql 8 (Zabbix Server 和 Zabbix Proxy 需要使用独立的数据库, ip 192.168.152.1)
  • 被Zabbix Proxy监控的主机 Centos 7 (ip 192.168.152.145) 以下简称Server-C

二.安装Zabbix Proxy

  1. 在Proxy-Server安装Zabbix Proxy

    1. # rpm -Uvh https://repo.zabbix.com/zabbix/4.4/rhel/7/x86_64/zabbix-release-4.4-1.el7.noarch.rpm
    2. # yum install zabbix-proxy-mysql
  2. 配置Zabbix Proxy

    1. # vim /etc/zabbix/zabbix_proxy.conf

    修改以下配置

    1. # Zabbix Server地址
    2. Server=192.168.152.140
    3. # Proxy的Hostname (默认Zabbix proxy)
    4. Hostname=Proxy-Server
    5. # 数据库配置
    6. DBName=zabbix_proxy
    7. DBUser=zabbix
    8. DBPassword=zabbix
    9. DBPort=3306
    10. ########### Proxy 特有参数 ############
    11. # Proxy已经将数据同步给Server后,数据保留时间(小时)
    12. ProxyLocalBuffer=0
    13. # Proxy与Server失去连接后,数据保留时间(小时)
    14. ProxyOfflineBuffer=1
    15. # 心跳包频率(秒)
    16. HeartbeatFrequency=60
    17. #####################################
    18. StatsAllowedIP=0.0.0.0/0

    更多配置项可以参考官方配置

  3. 配置Mysql

    注: Zabbix Server和 Zabbix Proxy的数据库必须是分开独立的!!!

    1. # 新建zabbix_proxy数据库
    2. CREATE DATABASE zabbix_proxy DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_bin;
    3. # 给zabbix账号赋予权限
    4. GRANT ALL PRIVILEGES ON zabbix_proxy.* TO 'zabbix'@'%';

    初始化schema

    1. # zcat /usr/share/doc/zabbix-proxy-mysql*/schema.sql.gz | mysql -uzabbix -pzabbix -Dzabbix_proxy -h192.168.152.1 -Dzabbix_proxy
  4. 启动Zabbix Proxy

    1. # systemctl start zabbix-proxy


三.Zabbix Server页面配置Proxy

点击【管理】-【agent代理程序】-【创建代理】

配置项
* agent代理程序名称 Proxy-Server
系统代理程序模式 主动式
代理地址 192.168.152.144


Server与Proxy保持连接


四.利用Proxy监控主机

至此Zabbix Proxy已经启动完成,接下来就将利用Proxy-Server来监控Server-C。和使用Zabbix Server监控类似,被监控主机安装Zabbix agent,只步过agent需要proxy来监控。

  1. Server-C安装Zabbix agent

    1. # rpm -Uvh https://repo.zabbix.com/zabbix/4.4/rhel/7/x86_64/zabbix-release-4.4-1.el7.noarch.rpm
    2. # yum install -y zabbix-agent
  2. 配置Server-C的agent

    1. # vim /etc/zabbix/zabbix_agentd.conf

    配置项

    1. # Server连接到Proxy的地址
    2. Server=192.168.152.144
    3. ServerActive=192.168.152.144
    4. # Server-C的hostname
    5. Hostname=Server-C
  3. 启动Server-C的agent

    1. # systemctl start zabbix-agent
  4. 在Zabbix Server界面增加Server-C

    增加【主机】

    配置项
    * 主机名称 Server-C
    * 群组 Linux servers
    agent代理程序的接口 (IP地址) 192.168.152.145
    agent代理程序的接口 (端口) 10050
    由agent代理程序监测 Proxy-Server


    链接模板



至此,Server-C已经通过Zabbix Proxy进行监控,Proxy定时发送监控数据给Server,实现了分布式监控。新增监控项或者JMX监控可以参考我之前的文章。

Zabbix-(七)分布式监控的更多相关文章

  1. Zabbix Proxy 分布式监控

    简介: Zabbix 是一个分布式监控系统,它可以以一个中心点.多个分节点的模式运行,使用 proxy 能降低 Zabbix Server 的压力,当然也带来了成本~ 适用范围:跨机房.跨地域的网络监 ...

  2. zabbix proxy分布式监控部署

    一.proxy分布式监控介绍 来源于zabbix官网: https://www.zabbix.com/documentation/3.4/zh/manual/distributed_monitorin ...

  3. (33)zabbix proxy分布式监控配置

    概述 zabbix proxy可以代替zabbix server检索客户端的数据,然后把数据汇报给zabbix server,并且在一定程度上分担了zabbix server的压力.zabbix pr ...

  4. 【Zabbix】分布式监控系统Zabbix【一】

    一.Zabbix功能及特性简介 Zabbix可以获取cpu,内存,网卡,磁盘,日志等信息 1.Zabbix数据收集方式: a.Agent客户端(Agent客户端支持多平台部署) b.如果是无法安装客户 ...

  5. Grafana + Zabbix --- 部署分布式监控系统

    阅读目录: 1. 关闭防火墙 2. 安装Zabbix下载源 3. ZabbixClient  --- 安装zabbix-agent代理 4. ZabbixServer --- 安装zabbix-ser ...

  6. 【Zabbix】分布式监控系统Zabbix【二】

    一.Zabbix基本操作 1.主机群组.主机.模板.触发器 a.创建主机群组和主机的过程比较简单,不再介绍 b.配置模板: 创建一个模板,将其分组到Template组,添加配置应用: 给应用创建监控项 ...

  7. 8、zabbix监控方式及分布式监控(04)

    zabbix支持的监控方式 zabbix所能够显示的且可指定为监控接口类型的监控方式: Agent passive active SNMP:Simple Network Management Prot ...

  8. 分布式系统监视zabbix讲解七之分布式监控--技术流ken

    分布式监控 概述 Zabbix通过Zabbix proxy为IT基础设施提供有效和可用的分布式监控 代理(proxy)可用于代替Zabbix server本地收集数据,然后将数据报告给服务器. Pro ...

  9. 分布式系统监视zabbix讲解七之分布式监控

    分布式监控 概述 Zabbix通过Zabbix proxy为IT基础设施提供有效和可用的分布式监控 代理(proxy)可用于代替Zabbix server本地收集数据,然后将数据报告给服务器. Pro ...

  10. LNMP+zabbix分布式监控搭建及版本升级

    LNMP+zabbix分布式监控搭建需要组件:gcc gcc-c++ openssl* pcre pcre-devel gd gd-devel libjpeg-devel libpng-devel l ...

随机推荐

  1. 【GTK编程】安装与测试

    版权声明:本文为博主原创文章,转载请注明出处. https://www.cnblogs.com/YaoYing/ 前言 领导让做个类似平板触摸的GUI程序,通过触摸两块区域,实现背景图片的左右切换.本 ...

  2. VMware Centos中创建克隆虚拟机导致网卡设备无法启动的问题

    一.前言 在创建克隆虚拟机的时候,如果样板虚拟机没有事先配置好,则会导致网卡设备无法启动的问题(报错如下). Bringing up interface eth0: Device eth0 does ...

  3. AQS系列(三)- ReentrantReadWriteLock读写锁的加锁

    前言 前两篇我们讲述了ReentrantLock的加锁释放锁过程,相对而言比较简单,本篇进入深水区,看看ReentrantReadWriteLock-读写锁的加锁过程是如何实现的,继续拜读老Lea凌厉 ...

  4. Spark Streaming vs. Structured Streaming

    简介 Spark Streaming Spark Streaming是spark最初的流处理框架,使用了微批的形式来进行流处理. 提供了基于RDDs的Dstream API,每个时间间隔内的数据为一个 ...

  5. public class 和 class的区别

    问题:public class 和 class的区别 public class 公共类 class 普通类 一个java源文件中可以有多个class,但是最多只能有一个public class 可以没 ...

  6. c++-面向对象类的示例-求周长面积,判断体积相等-文件操作和一般操作

    面向对象编程示例:求周长和面积 #define _CRT_SECURE_NO_WARNINGS #include <iostream> using namespace std; //圆的周 ...

  7. Nezuko: 1 Vulnhub Walkthrough

    下载地址: https://www.vulnhub.com/entry/nezuko-1,352/ 虚拟机启动,设置IP地址DHCP获取 主机发现扫描: 主机层面扫描: ╰─ nmap -p1-655 ...

  8. sqlserver update join 多关联更新

    由于程序bug,导致之前很多数据入库后信息不全,好在有基础信息表,可以通过基础信息表更新缺失字段信息 1.通过 inner join语法实现多关联更新 update a set a.name = b. ...

  9. docker拉取慢(net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting head)

    systemctl restart docker在docker-hub拉取慢,因为服务器在外网 直接配置阿里云镜像就可以 首先: vim /etc/docker/daemon.json加入下面的那句 ...

  10. asp.net core 系列 9 三种运行环境和IIS发布

    一.在asp.net core中使用多个环境 ASP.NET Core 配置是基于运行时环境, 使用环境变量.ASP.NET Core 在应用启动时读取环境变量ASPNETCORE_ENVIRONME ...