首页 > 其他分享 >分布式监控平台------Zabbix

分布式监控平台------Zabbix

时间:2023-04-11 20:02:18浏览次数:40  
标签:数据库 zabbix agent server Zabbix proxy 监控 ------ 分布式

一、Zabbix概述

作为一个运维,需要会使用监控系统查看服务器状态以及网站流量指标,利用监控系统的数据去了解上线发布的结果,和网站的健康状态。

利用一个优秀的监控软件,我们可以:
●通过一个友好的界面进行浏览整个网站所有的服务器状态
●可以在 Web 前端方便的查看监控数据
●可以回溯寻找事故发生时系统的问题和报警情况

1. zabbix是什么

●zabbix 是一个基于 Web 界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。
●zabbix 能监视各种网络参数,保证服务器系统的安全运营;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。
●zabbix 由 2 部分构成,zabbix server 与可选组件 zabbix agent。通过 C/S 模式采集数据,通过 B/S 模式在 Web 端展示和配置。
●zabbix server 可以通过 SNMP,zabbix agent,ping,端口监视等方法提供对远程服务器/网络状态的监视,数据收集等功能, 它可以运行在 Linux 等平台上。
●zabbix agent 需要安装在被监视的目标服务器上,它主要完成对硬件信息或与操作系统有关的内存,CPU 等信息的收集。

2. zabbix 主要特点及功能

特点:免费开源 自动发现服务与网络设备分布式 可以监监视以及web集中管理功能安全认证 监视结果通过email通知运维(管理员)

功能:cpu负载 内存管理 磁盘使用 网络状态 端口监视 日志监视 中间件监视 插件开发自定义(只能监控传统,不能监控容器)

3. zabbix运行机制

zabbix server (端口10051)和 zabbix agent(端口10050)    c/s
客户端负责采集数据,给服务端;服务端通过b/s模式,在web端展示和配置

 

4. zabbix数据流向、工作原理

数据流向:zabbix-agent(数据采集)-- zabbix-server(数据分析、告警)--数据库(数据存储)--zabbix-web(数据展示)

工作原理:zabbix在进行监控时,zabbix客户端要安装在被监控设备上,负责定期收集数据,并将其发送给zabbix服务端;zabbix服务端安装在监控设备上,其将zabbix客户端发送的数据存储在我们的数据库中,zabbixweb根据在前端进行展示和绘图

 

5. zabbix常见的五个程序

zabbix 监控部署在系统中,包含常见的五个程序: zabbix_server、zabbix_agent、zabbix_proxy、zabbix_get、zabbix_sender 等。
●zabbix server:zabbix 服务端守护进程,其中 zabbix_agent、zabbix_get、zabbix_sender、zabbix_proxy 的数据最终都提交给 zabbix server;
●zabbix agent:客户端守护进程,负责收集客户端数据,例如:收集 CPU 负载、内存、硬盘使用情况等;
●zabbix proxy:zabbix 分布式代理守护进程,通常大于 500 台主机,需要进行分布式监控架构部署;
●zabbix get:zabbix 数据接收工具,单独使用的命令,通常在 server 或者 proxy 端执行获取远程客户端信息的命令;
●zabbix sender:zabbix 数据发送工具,用户发送数据给 server 或 proxy 端,通常用户耗时比较长的检查。

6. zabbix常见架构

①server-client架构

服务端与客户端

监控机器与被监控机器之间不经过任何出处理,直接由zabbix-server和zabbix-agent之间进行数据交换,适用于网络比较啊简单,尽量在局域网内,设备比较少的监控环境

 ②server-proxy-client架构(多一个代理)

server-proxy-client 其中proxy是 server、client之间的桥梁,proxy本身没有前端,而且本身并不存放数据,只是将agentd发出数据暂时存放,而后在提交给server,这种架构经常是和master-node-client架构做比较的架构,一般适用于跨机房、跨网络的中型网络架构的监控。

③master-node-client架构(适合大型数据平台)

master-node-client架构,该架构是zabbix最复杂的监控架构,适用于跨网络、跨机房、设备较多的大型环境。每一个node同时一个server端口,node下面可以杰proxy,也可以直接接client。node有自己的配置文件和数据库,其要做的是将配置信息和监控数据向master同步,master故障或损坏对node其下架的完整性。

二、安装Zabbix

1. 部署zabix服务端(端口号10051)

 1 zabbix-server 内存至少 2G,推荐 4G;
 2 服务端机器192.168.50.170
 3 systemctl disable --now firewalld
 4 setenforce 0
 5 hostnamectl set-hostname zbx-server
 6 
 7 //获取 zabbix 的下载源
 8 rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm 
 9 
10 //更换 zabbix.repo 为阿里源
11 cd /etc/yum.repos.d
12 sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' zabbix.repo
13 
14 yum clean all && yum makecache
15 
16 yum install -y zabbix-server-mysql zabbix-agent
17 
18 //安装SCL(Software Collections),便于后续安装高版本的 php,默认 yum 安装的 php 版本为 5.4,版本过低,zabbix 5.0 版本对 php 版本最低要 7.2.0 版本。SCL 可以使得在同一台机器上使用多个版本的软件,而又不会影响整个系统的依赖环境。软件包会安装在 /opt/rh 目录下。
19 
20 yum install -y centos-release-scl 
21 
22 //修改 zabbix-front 前端源,安装 zabbix 前端环境到 scl 环境下
23 vim zabbix.repo
24 ......
25 [zabbix-frontend]
26 ......
27 enabled=1          #开启安装源
28 ......
29 
30 yum install -y zabbix-web-mysql-scl zabbix-apache-conf-scl
31 
32 //安装 zabbix 所需的数据库
33 yum install -y mariadb-server mariadb
34 
35 systemctl enable --now mariadb
36 
37 mysql_secure_installation         #初始化数据库,并设置密码,如 abc123
38 
39 //添加数据库用户,以及 zabbix 所需的数据库信息
40 mysql -u root -pabc123
41 
42 CREATE DATABASE zabbix character set utf8 collate utf8_bin;
43 GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';
44 flush privileges;
45 
46 //导入数据库信息
47 rpm -ql zabbix-server-mysql         #查询 sql 文件的位置
48 
49 zcat /usr/share/doc/zabbix-server-mysql-5.0.33/create.sql.gz | mysql -uroot -pabc123 zabbix
50 
51 //修改 zabbix server 配置文件,修改数据库的密码
52 vim /etc/zabbix/zabbix_server.conf 
53 ......
54 DBPassword=zabbix                    #124行,指定 zabbix 数据库的密码
55 
56 //修改 zabbix 的 php 配置文件
57 vim /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf
58 ......
59 php_value[date.timezone] = Asia/Shanghai        #24行,取消注释,修改时区
60 
61 //启动 zabbix 相关服务
62 systemctl restart zabbix-server zabbix-agent httpd rh-php72-php-fpm
63 systemctl enable zabbix-server zabbix-agent httpd rh-php72-php-fpm
64 
65 浏览器访问:http://192.168.50.170/zabbix
66 点击下一步,设置数据库的密码 zabbix
67 设置文件界面:点击左边菜单栏的【User settings】,【Language】选择 Chinese(zh_CN),再点击 Update 更
68 安装完成后,默认的登录账号和密码为:Admin/zabbix新。
69 
70 //解决 zabbix-server Web页面中文乱码问题
71 yum install -y wqy-microhei-fonts
72 
73 \cp -f /usr/share/fonts/wqy-microhei/wqy-microhei.ttc /usr/share/fonts/dejavu/DejaVuSans.ttf

①关闭防火墙、安全防护模块,修改主机名

 ②获取zabbix下载源

 ③更换 zabbix.repo 为阿里源,安装zabbix-server-mysql、zabbix-agent和SCL

 ④修改 zabbix-front 前端源,开启安装源;安装 zabbix 前端环境到 scl 环境下

 ⑤安装zabbix所需的数据库

 ⑥添加数据库用户,以及 zabbix 所需的数据库信息

 ⑦修改 zabbix-server 配置文件/etc/zabbix/zabbix_server.conf,修改数据库的密码。

 ⑧修改 zabbix 的 php 配置文件,/etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf

 ⑨启动 zabbix 相关服务

 ⑩浏览器访问http://192.168.50.170/zabbix

下图原本都是英文模式,实验后面进行语言切换才变为中文的

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

解决 zabbix-server Web页面中文乱码问题

 

 

标签:数据库,zabbix,agent,server,Zabbix,proxy,监控,------,分布式
From: https://www.cnblogs.com/daiwei-123/p/17307449.html

相关文章

  • flask框架06 sqlalchemy使用 scoped_session线程安全 一对多 多对多 增删改查
    今日内容详细目录今日内容详细1sqlalchemy快速插入数据2scoped_session线程安全2.1基本使用2.2加在类上的装饰器3基本增删查改3.1基本增删查改和高级查询3.2原生sql3.3django中执行原生sql4一对多4.1表模型4.2新增和基于对象的查询5多对多5.1表模型5.2增加和基于......
  • 逃离迷宫
    有一个n*m大小的迷宫。其中字符\(S\)表示起点,字符\(D\)表示出口,字符\(X\)表示墙壁,字符\(.\)表示平地。你需要从\(S\)走到\(D\),每次只能向上下左右相邻的位置移动,并且不能走出地图,也不能走进墙壁。若每次移动消耗1时间,走过路都会塌陷,因此不能走回头路或原地不动。现在已知出......
  • QuartZ Cron表达式简记
    表达式范例:*/5****?每隔5秒执行一次0*/1***?每隔1分钟执行一次0023**?每天23点执行一次001**?每天凌晨1点执行一次:0011*?每月1号凌晨1点执行一次0023L*?......
  • Java实现PDF转Word
    Java实现PDF转Word原文链接:https://blog.csdn.net/Mgg9702/article/details/1249874831、引入jar包或依赖这里用到的是aspose-pdf,这个依赖需要单独配置仓库地址,也可以直接去官网下载jar包<repositories> <repository> <id>AsposeJavaAPI</id> <name>AsposeJavaAPI<......
  • Kubernetes客户端认证(二)—— 基于ServiceAccount的JWTToken认证
    1、概述在Kubernetes官方手册中给出了“用户”的概念,Kubernetes集群中存在的用户包括“普通用户”与“ServiceAccount”,但是Kubernetes没有普通用户的管理方式,通常只是将使用集群根证书签署的有效证书的用户都被视为合法用户。那么对于使得Kubernetes集群......
  • 清除浮动之双伪元素
    <!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metaname="viewport"content="width=device-width,initial-scale=1.0"><metahttp-equiv="X-UA-Compati......
  • uni-app(5)
    uni-app(5)static目录下的文件不会被编译,如果这里面有es6代码,不经过转换直接运行,则会报错;同样的,less、scss等资源也不要放入这里面根目录中的uni.scss会自动引入uni-app完整支持Vue里面的生命周期,此外,还包括它本身的应用生命周期和页面生命周期使用onPullDownRefre......
  • ros-python学习样例笔记
    1.通信基本原理介绍待写2.三种通信方式的程序样例(python版)2.1topic通信方式(非自定义和自定义)2.1.1创建工作空间和topic功能包在ubuntu中打开命令行,输入下面的命令创建并初始化工作空间,一定要回到XXX_ws的目录下初始化工作空间#创建工作空间文件夹my_ros(一般命名......
  • 将TDateTime值分解为小时、分钟、秒和毫秒,以及计算时间差
     将时间日期分解procedureTForm1.Button1Click(Sender:TObject);varPresent:TDateTime;Year,Month,Day,Hour,Min,Sec,MSec:Word;beginPresent:=Now;SysUtils.DecodeDate(Present,Year,Month,Day);Label1.Caption:='TodayisDay'+I......
  • Android脱壳基础知识
    JVM的类加载器:BootstrapClassLoader引导类加载器:C/C++代码实现的加载器,用于加载制定的JDK核心库,比如java.lang.*、java.util.*等这些系统类。Java虚拟机的启动就是通过Bootstrap,该ClassLoader在java里无法获取,负责加载/lib下的类ExtensionsClassLoader拓展类加载器:Java中的......