Zabbix监控系统详解2:基于Proxy分布式实现Web应用监控及Zabbix 高可用集群的搭建

文章目录

  • 1. zabbix-proxy的分布式监控的概述
    • 1.1 分布式监控的主要作用
    • 1.2 监控数据流向
    • 1.3 构成组件
      • 1.3.1 zabbix-server
      • 1.3.2 Database
      • 1.3.3 zabbix-proxy
      • 1.3.4 zabbix-agent
      • 1.3.5 web 界面
  • 2. 部署zabbix代理服务器
    • 2.1 前置准备
    • 2.2 配置 zabbix 的下载源,安装 zabbix-proxy
    • 2.3 部署数据库并导入zabbix相关文件
    • 2.4 编辑zabbix-proxy的配置文件并启动服务
    • 2.5 在所有主机上配置 hosts 解析
    • 2.6 在 Web 页面配置 agent 代理
    • 2.7 在客户端修改 agent2 配置文件
    • 2.8 在 Web 页面添加客户端主机
    • 2.9 分别在客户端和代理服务器上重启服务
    • 2.10 在代理服务器查看日志
  • 3. 部署 Zabbix 高可用集群
    • 3.1 前置准备
    • 3.2 服务端配置
      • 3.2.1 配置主节点 zabbix-server
      • 3.2.2 配置备节点 Zabbix Server
      • 3.2.3 主备节点添加监控主机
      • 3.2.4 查看高可用集群状态
    • 3.3 配置客户端
      • 3.3.1 修改agent01和agent02的配置文件
      • 3.3.2 查看Web页面
  • 4. 故障切换测试
    • 4.1 模拟server01节点出现故障,观察Web前端页面
    • 4.2 观察是否成功故障切换

1. zabbix-proxy的分布式监控的概述

在这里插入图片描述

1.1 分布式监控的主要作用

  1. 分担 server 的集中式压力;

  2. 解决多机房之间的网络延时问题。

1.2 监控数据流向

在这里插入图片描述

1.3 构成组件

1.3.1 zabbix-server

整个监控体系中最核心的组件,它负责接收客户端发送的报告信息,所有配置、 统计数据及操作数据都由它组织。

1.3.2 Database

所有配置信息和zabbix收集到的数据都存储在数据库中。

1.3.3 zabbix-proxy

用于分布式系统中,可以代理zabbix-server的功能,减轻server的压力

1.3.4 zabbix-agent

客户端软件,装在被监控主机上,用于采集监控数据,并把采集到的的数据发送给proxy或者server。

1.3.5 web 界面

web界面可以让用户随时随地都能够轻松的访问到zabbix,是zabbix-server的一部分,通常跟server运行在同一台物理机上

2. 部署zabbix代理服务器

在这里插入图片描述

2.1 前置准备

zabbix-server	192.168.67.100
zabbix-agent01	192.168.67.101
zabbix-agent02	192.168.67.102
zabbix-proxy	192.168.67.103
systemctl stop firewalld
setenforce 0

2.2 配置 zabbix 的下载源,安装 zabbix-proxy

rpm -ivh https://repo.zabbix.com/zabbix/6.0/rhel/7/x86_64/zabbix-release-6.0-4.el7.noarch.rpm
sed -i 's#https://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' /etc/yum.repos.d/zabbix.repoyum install -y zabbix-proxy-mysql zabbix-sql-scripts zabbix-selinux-policy

在这里插入图片描述

2.3 部署数据库并导入zabbix相关文件

#配置 Mariadb yum源
cat > /etc/yum.repos.d/mariadb.repo << EOF
[mariadb]
name = MariaDB
baseurl = http://mirrors.aliyun.com/mariadb/yum/10.5/centos7-amd64/
gpgkey = http://mirrors.aliyun.com/mariadb/yum/RPM-GPG-KEY-MariaDB
gpgcheck = 1
enabled=1
EOF#安装mariaDB
yum install -y mariadb-server mariadb#启动
systemctl enable --now mariadb

在这里插入图片描述

#初始化数据库
mysql_secure_installation
分别输入 回车 -> n -> Y (设置root密码,如abc123) -> 后面一路 Ymysql -u root -pabc123

在这里插入图片描述

#创建数据库并指定字符集
create database zabbix_proxy character set utf8 collate utf8_bin;#创建 zabbix 数据库用户并授权
grant all on zabbix_proxy.* to 'zabbix'@'localhost' identified by 'zabbix';
grant all on zabbix_proxy.* to 'zabbix'@'%' identified by 'zabbix';flush privileges;
#刷新权限

在这里插入图片描述

#导入数据库信息
rpm -ql zabbix-sql-scripts 		#查询 sql 文件的位置cat /usr/share/zabbix-sql-scripts/mysql/proxy.sql | mysql -uroot -pabc123 zabbix_proxy

2.4 编辑zabbix-proxy的配置文件并启动服务

#修改 zabbix-proxy 配置文件
vim /etc/zabbix/zabbix_proxy.conf#修改以下项
Server=192.168.67.100				#32行,指定 zabbix 服务端的 IP 地址
Hostname=zbx-proxy					#42行,指定当前 zabbix 代理服务器的主机名
DBPassword=zabbix					#194行,指定当前数据库 zabbix 用户的密码

在这里插入图片描述
在这里插入图片描述

#启动 zabbix-proxy
systemctl enable zabbix-proxy --now;systemctl status zabbix-proxy

在这里插入图片描述

2.5 在所有主机上配置 hosts 解析

cat > /etc/hosts << EOF
192.168.67.100 zbx-server
192.168.67.101 zbx-agent01
192.168.67.102 zbx-agent02
192.168.67.103 zbx-proxy
EOF

在这里插入图片描述

2.6 在 Web 页面配置 agent 代理

点击左边菜单栏【配置】中的【动作】,勾选自动注册规则,点击 禁用
点击左边菜单栏【配置】中的【主机】,勾选原有的客户端主机,点击 删除

在这里插入图片描述
在这里插入图片描述

点击左边菜单栏【管理】中的【agent代理程序】,点击【创建代理】
【agent代理程序名称】输入 zbx-proxy
【系统代理程序模式】选择 主动式
【代理地址】输入 192.168.67.103
点击 【添加】

在这里插入图片描述
在这里插入图片描述

2.7 在客户端修改 agent2 配置文件

#更改所有客户端
vim /etc/zabbix/zabbix_agent2.conf
......
Server=192.168.67.103		#80行,指定 zabbix 代理服务器的 IP 地址
ServerActive=192.168.67.103:10051	#120行,指定 zabbix 代理服务器的 IP 地址

在这里插入图片描述
在这里插入图片描述

2.8 在 Web 页面添加客户端主机

#zbx-agent01
点击左边菜单栏【配置】中的【主机】,点击【创建主机】
【主机名称】输入 zbx-agent01
【可见的名称】输入 zbx-agent01
【模板】搜索 Linux ,选择 Linux by Zabbix agent
【群组】选择 Linux server
【Interfaces】选择 客户端,【IP地址】输入 192.168.2.102,【端口】输入 10050
【由agent代理程序监测】选择 zbx-proxy
点击 【添加】

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

2.9 分别在客户端和代理服务器上重启服务

systemctl restart zabbix-agent2systemctl restart zabbix-proxy
等待一段时间后,点击左边菜单栏【配置】中的【主机】刷新,查看客户端主机监控状态正常

在这里插入图片描述

2.10 在代理服务器查看日志

tail -f /var/log/zabbix/zabbix_proxy.log

在这里插入图片描述

3. 部署 Zabbix 高可用集群

在这里插入图片描述

3.1 前置准备

zabbix-server01	192.168.67.100
zabbix-server02	192.168.67.103
zabbix-agent01	192.168.2.101
zabbix-agent02	192.168.2.102

3.2 服务端配置

zabbix-server01zabbix-server02都要部署zabbix服务端,详情见Zabbix监控系统详解1 :zabbix服务部署、自定义监控项、自动发现与自动注册

默认情况下,HA 是关闭的。

HA 部分的配置在配置文件的最下面:High availability cluster parameters 部分

3.2.1 配置主节点 zabbix-server

在这里插入图片描述

#主节点 Zabbix Server 配置
vim /etc/zabbix/zabbix_server.conf
......
DBHost=192.168.67.100
DBName=zabbix
DBUser=zabbix
DBPassword=zabbix
......
HANodeName=zbx-server01					#设置为当前节点主机名
NodeAddress=192.168.67.100:10051			#设置为节点IPsystemctl restart zabbix-server

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

#主节点给数据库授权远程登录权限
mysql -uroot -pabc123
GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';
FLUSH PRIVILEGES;

在这里插入图片描述

3.2.2 配置备节点 Zabbix Server

在这里插入图片描述

#备节点 Zabbix Server 配置
vim /etc/zabbix/zabbix_server.conf
......
DBHost=192.168.67.103 #87 
DBName=zabbix #99
DBUser=zabbix #115
DBPassword=zabbix #123
......
HANodeName=zbx-server02
NodeAddress=192.168.67.103:10051

在这里插入图片描述
在这里插入图片描述

systemctl restart zabbix-server

3.2.3 主备节点添加监控主机

主备配置文件基本相同,以下以主服务器为例

点击左边菜单栏【配置】中的【主机】,点击【创建主机】

在这里插入图片描述

【主机名称】输入 zbx-agent01
【可见的名称】输入 zbx-agent01-192.168.67.101
【模板】搜索 Linux ,选择 Linux by Zabbix agent
【群组】选择 Linux servers
【Interfaces】点击添加 客户端
【IP地址】输入 192.168.67.101

在这里插入图片描述
在这里插入图片描述

3.2.4 查看高可用集群状态

打开Web页面
选择报表-->系统信息
查看高可用集群项是否已经启用

在这里插入图片描述

在这里插入图片描述

3.3 配置客户端

3.3.1 修改agent01和agent02的配置文件

需要在agent配置文件中将所有的Server节点地址配置到Server和ServerActive中

vim /etc/zabbix/zabbix_agent2.conf 
......
Server=192.168.67.100,192.168.67.101,192.168.67.102,192.168.67.103
ServerActive=192.168.67.100;192.168.67.101;192.168.67.102;192.168.67.103
#注意,ServerActive 的连接符是‘;’ ,而不是‘,’

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

systemctl restart zabbix-agent2.service

3.3.2 查看Web页面

在这里插入图片描述
在这里插入图片描述

4. 故障切换测试

当zabbix监控主服务器挂掉时,观察能否自动故障切换

4.1 模拟server01节点出现故障,观察Web前端页面

#切换到zabbix-server01
systemctl stop zabbix-server

在这里插入图片描述

4.2 观察是否成功故障切换

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/105346.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

零代码编程:用ChatGPT批量采集bookroo网页上的英文书目列表

bookroo网页上有很多不错的英文图书书目。比如这个关于儿童花样滑冰的书单&#xff1a; https://bookroo.com/explore/books/topics/ice-skating 怎么批量下载下来呢&#xff1f; 这个网页是动态网页&#xff0c;要爬取下来比较麻烦&#xff0c;可以先查看源代码&#xff0c;…

Golang中gRPC使用及原理探究

文章目录 概述gRPC的优势&#xff1a; 1、gRPC入门1.1 protobuf安装1.2 使用gRPC1.2.1 定义proto文件1.2.2 编译proto文件1.2.3 编写客户端和服务端代码 2、gRPC的通信模式2.1 一元RPC模式2.2 客户端流RPC模式2.3 服务端流RPC模式2.4双向流RPC模式 3、 gRPC的底层原理探究3.1 H…

P1433 吃奶酪

#include <iostream> #include <cmath> using namespace std; #define M 15 #define S(n) ((n) * (n)) double indx[M 5], indy[M 5], ans 0, sum 0;//坐标数组&#xff0c;从下标为1开始记录 int n, vis[M 5] { 0 };//vis数组&#xff0c;选过的数字标记为1…

关于pytorch不区分行向量与列向量的理解

听李沐老师讲深度学习时候解释pytorch不区分行向量和列向量&#xff0c;只相当于是一维数组&#xff0c;一维张量一定是行向量&#xff0c;相当于数组&#xff0c;而行列向量可以放到矩阵中看。 测试如下&#xff1a; rtorch.tensor([1,2,3],dtypetorch.float32) print(r,r.T…

滑动窗口算法(C语言描述)

第一种类型&#xff1a;不固定长窗口 问题1&#xff1a;*** C代码1&#xff1a; #include<stdio.h> #include<string.h> #define N 5int min_len(int len1,int len2) {return (len1 < len2 ? len1:len2); }int main() {int target 0;int num[N];scanf("…

C语言中的文件操作指南

阅读导航 前言一、文件类型1. 程序文件2. 数据文件PS.文件名 二、文件的打开和关闭1. 文件指针2. 文件的打开和关闭 三、文件的顺序读写四、文件的随机读写1. fseek() 函数2. ftell() 函数3. rewind() 函数 总结 前言 在C语言中&#xff0c;文件操作是一项重要的任务。通过文件…

阿里云在云原生领域喜获多项 OSCAR 开源尖峰案例奖

当前&#xff0c;国内开源技术正逐渐在各领域落地&#xff0c;越来越多的企业已经或准备使用开源&#xff0c;优秀的开源案例可以起到领航和参考作用。为了更好地推动开源技术在中国市场的落地&#xff0c;鼓励企业和厂商使用开源&#xff0c;鼓励企业或个人进一步探索我国开源…

矩阵系统能做什么

矩阵系统可以应用于许多领域&#xff0c;包括但不限于以下方面&#xff1a; 1. 工程领域&#xff1a;在工程项目中&#xff0c;矩阵系统可用于设计和优化结构、系统、网络、电路、热管理等。例如&#xff0c;矩阵系统可以用来分析和预测系统的稳定性、可靠性、响应时间、能耗等…

2023年中国分布式光纤传感产量、需求量及行业市场规模分析[图]

分布式光纤传感器中的光纤能够集传感、传输功能于一体&#xff0c;能够完成在整条光纤长度上环境参量的空间、时间多维连续测量&#xff0c;具有结构简单、易于布设、性价比高、易实现长距离等独特优点&#xff0c;常用的分布式光纤传感器有光时域反射仪、布里渊分析仪、喇曼反…

Outlook导入导出功能灰色,怎么解决

下载安装 Outlook 软件后&#xff0c;登陆账号&#xff0c;然后选择“文件” - “导出”&#xff0c;结果发现“导出”按钮是灰色的&#xff0c;根本无法导出。根据官方说法&#xff1a;由于配置没有完成或者office产品没有正确激活。outlook导出键为灰色原因由于配置没有完成或…

基于nodejs+vue教学辅助管理系统

学生&#xff1b;首页、个人中心、本课程设计了线上教学辅助系统 ,学生可以此系统实现在线学习&#xff0c;作业提交管理、作业成绩管理。随着社会的快速发展&#xff0c;计算机的影响是全面且深入的。教师&#xff1a;首页、个人中心、课程信息管理、教学资料管理、作业信息管…

IDEA的使用(四)创建不同类型的工程(IntelliJ IDEA 2022.1.3版本)

1. 创建Java工程 创建之后&#xff0c;src下是空的。可以在src下创建软件包Package&#xff0c;命名采用域名倒序。在软件包下再创建Java类。Java类运行后出现中文乱码&#xff0c;就到控制台和文件编码这两个地方设置编码。 2. 创建JavaWeb工程 2.1 在win11和IDEA中配置Tomca…

《UnityShader入门精要》学习4

一个最简单的顶点/片元着色器 一个最简单的顶点/片元着色器 Unity Shader的基本结构。它包含了Shader、Properties、SubShader、Fallback等语义块。顶点/片元着色器的结构与之大体类似 Shader "MyShaderName" {Properties {// 属性}SubShader {// 针对显卡A的S…

opencv图形绘制2

目录 制作宣传语&#xff08;中文&#xff09; 制作宣传语&#xff08;英文&#xff09; 绘制标记 鼠标交互绘制十字线 鼠标交互绘制图形 鼠标交互制作几何画板 滚动条控制 鼠标事件练习 制作宣传语&#xff08;中文&#xff09; import cv2 import numpy as np from …

实现Element Select选择器滚动加载

<template><el-selectpopper-class"more-tag-data"v-model"tagId"filterableplaceholder"请选择"focus"focusTag"><el-optionv-for"(item, index) in taskTagLists":key"index":label"item.n…

互联网Java工程师面试题·Java 并发编程篇·第七弹

目录 16、CAS 的问题 17、什么是 Future&#xff1f; 18、什么是 AQS 19、AQS 支持两种同步方式&#xff1a; 20、ReadWriteLock 是什么 21、FutureTask 是什么 22、synchronized 和 ReentrantLock 的区别 23、什么是乐观锁和悲观锁 24、线程 B 怎么知道线程 A 修改了…

蓝桥杯 枚举算法 (c++)

枚举就是根据提出的问题&#xff0c;——列出该问题的所有可能的解&#xff0c;并在逐一列出的过程中&#xff0c;检验每个可能解是否是问题的真正解&#xff0c; 如果是就采纳这个解&#xff0c;如果不是就继续判断下一个。 枚举法一般比较直观&#xff0c;容易理解&#xff0…

完美解决lftp遇到put: Access failed: 553 Could not create file.

目录 一、问题 二、原因 三、解决方法 一、问题 put: Access failed: 553 Could not create file. 二、原因 &#xff08;1&#xff09;没有关闭SeLinux &#xff08;2&#xff09;linux默认安装vsftp服务之后只允许匿名用户的访问和下载&#xff0c;不支持上传。 三、解决方…

matlab 图像均值滤波

目录 一、算法原理二、代码实现三、结果展示本文由CSDN点云侠翻译,放入付费专栏只为防不要脸的爬虫。专栏值钱的不是本文,切勿因本文而订阅。 一、算法原理 均值滤波是一种常用的线性滤波方法,用于平滑图像并减少噪声。它的实现过程如下: 确定滤波器的大小:选择一个固定的…

P1443 马的遍历

#include <iostream> #include <queue> using namespace std; #define M 400 int arr[M 5][M 5]; typedef struct Node {int x, y; } Node; //将马能走的8个方向封装成一个二维数组 int dir[8][2] {{2, 1}, {2, -1}, {-2, 1}, {-2, -1},{1, 2}, {-1, 2}, {1, -2…