zabbix

zabbix版本5.0 4.6 6.4

定义:

zabbix是一个基于web界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。zabbix能监视各种网络参数,保证服务器系统的安全运营;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。

组成:

zabbix 由⒉部分构成,zabbix server与可选组件 zabbix agent。J通过c/s模式采集数据,通过B/s模式在 web端展示和配置。

zabbix server可以通过SNMP,zabbix

agent,ping,端口监视等方法提供对远程服务器/网络状态的监视,数据收集等功能,它可以运行在Linux等平台上。

zabbix agent

需要安装在被监视的目标服务器上,它主要完成对硬件信息或与操作系统有关的内存,cPU等信息的收集。

zabbix监控原理

zabbix agent安装在被监控的主机上,zabbix

agent负责定期收集客户端本地各项数据,并发送至 zabbix server端,zabbix server收到数据后,将数据存储到数据库中,用户基于Zabbix WEB可以看到数据在前端展现图像。当zabbix 监控某个具体的项目,该项目会设置一个触发器阈值,当被监控的指标超过该触发器设定的阈值,会进行一些必要的动作,动作包括:发送信息(邮件、微信、短信)、发送命令(shell命令、 reboot、 restart、 install等)。
监控对象:硬件监控 系统监控 java监控 网络设备监控 应用服务监控 mysql数据库监控

URL监控部署在系统中,包含常见的五个程序:

zabbix_server、zabbix_agent、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端,通常用户耗时比较长的检查。

主要特点:

安装与配置简单 学习成本低 支持多种语言(包括中文)

免费开源 自动发现服务器 通知功能 email 微信 电话 钉钉

主要功能:监控cpu内存 IO 网络 端口 日志等

运行机制 c/s zabbix_server zabbix_agent(安装在被监控端)

zabbix工作原理

在这里插入图片描述

采用了两种模式(面试)

主动模式:agent向server发起连接

被动模式:server向agent发起连接

监控架构

zabbix分布式架构

server-client架构

server-proxy-client架构
在这里插入图片描述
其实proxy是server和client沟通之间的桥梁,proxy本身就没有前端,而且其本身并不存放数据,只是将agent发来的数据暂时存放,而后再提交给server,这种架构是和master-node-client架构做比较的架构,一般适用于跨机房、跨网络或中型网络架构的监控

master-node-client架构

master和node其中一个挂了,没什么关系
在这里插入图片描述
zabbix五个应用程序

zabbix 5.0 4.6 6.4

安装zabbix

1.yum安装

2.编译安装 lamp lnmp

服务端

1、关闭防火墙,修改主机名

systemctl disable --now firewalld
setenforce 0
hostnamectl set-hostname zbx-server

在这里插入图片描述

2、获取 zabbix 的下载源

rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm

在这里插入图片描述

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

cd /etc/yum.repos.d
sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' zabbix.repo
yum clean all && yum makecache

在这里插入图片描述
安装zabbix-server-mysql和zabbix-agent

yum install -y zabbix-server-mysql zabbix-agent

在这里插入图片描述
安装SCL(Software Collections),便于后续安装高版本php

yum install -y centos-release-scl

在这里插入图片描述

4.修改zabbix-front前端源,安装zabbix前端环境到scl环境下

修改/etc/yum.repos.d/zabbix.repo

vim /etc/yum.repos.d/zabbix.repo

在这里插入图片描述

yum install -y zabbix-web-mysql-scl zabbix-apache-conf-scl

在这里插入图片描述

5.安装zabbix所需要的数据库

yum install -y mariadb-server mariadb

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

6.添加数据库用户,以及zabbix所需要数据库信息

mysql -u root -pabc123
create database zabbix character set utf8 collate utf8_bin;
grant all on zabbix.* to 'zabbix'@'%' identified by 'zabbix';
flush privileges;

在这里插入图片描述

7.查询已安装的zabbix-server-mysql的文件列表,找到sql.gz文件位置

rpm -ql zabbix-server-mysql
zcat /usr/share/doc/zabbix-server-mysql-5.0.36/create.sql.gz | mysql -uroot -pabc123 zabbix

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

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

vim /etc/zabbix/zabbix_server.conf
设置密码为zabbix

在这里插入图片描述

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

vim /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf

在这里插入图片描述

10.启动zabbix相关服务

systemctl restart zabbix-server zabbix-agent httpd rh-php72-php-fpm
systemctl enable zabbix-server zabbix-agent httpd rh-php72-php-fpm
netstat -natp | grep zabbix

在这里插入图片描述

11.浏览器访问http://192.168.109.1/zabbix

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

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

yum install -y wqy-microhei-fonts
 cp -f /usr/share/fonts/wqy-microhei/wqy-microhei.ttc /usr/share/fonts/dejavu/DejaVuSans.ttf 

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

部署zabbix客户端(端口号10050)

zabbix 5.0版本采用golang 语言开发的新版本客户端agent2 。

zabbix 服务端 zabbix_server 默认使用 10051 端口,客户端 zabbix_agent2 默认使用 10050 端口

1.关闭防火墙、修改主机名

systemctl disable --now firewalld
setenforce 0
hostnamectl set-hostname zbx-agent01
bash

在这里插入图片描述

2.服务端和客户端都配置时间同步

yum install -y ntpdate
ntpdate -u ntp.aliyun.com

在这里插入图片描述

3.客户端配置时区,与服务器保持一致

mv /etc/localtime{,.bak}
ln -s /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
date

在这里插入图片描述

4.设置zabbix的下载源,安装zabbix-agent2

rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm
sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' /etc/yum.repos.d/zabbix.repo

在这里插入图片描述

yum install -y zabbix-agent2

在这里插入图片描述

5.修改agent2配置文件,/etc/zabbix/zabbix_agent2.conf

vim /etc/zabbix/zabbix_agent2.conf

在这里插入图片描述

6.启动zabbix-agent2

systemctl start zabbix-agent2
systemctl enable zabbix-agent2
netstat -natp | grep zabbix

在这里插入图片描述

7.在服务端验证zabbix-agent2的连通性

yum install -y zabbix-get

在这里插入图片描述

zabbix_get -s '192.168.109.3' -p 10050 -k 'agent.ping'
zabbix_get -s '192.168.109.3' -p 10050 -k 'system.hostname'

在这里插入图片描述
2.3将客户端加入服务端的监控主机中

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

总结:

zookeeper 分布式服务框架,存储业务服务节点元数据信息,并且负责通知在zookeeper上注册的服务节点状态给客户端=文件系统+通知机制

1个leader n个follower 节点数量要是 >= 3的奇数台

第一次选举,通过比较myid,myid最大获取选票,当选票过半数确定leaderd的节点,之后再加入节点无论多大都作为follower加入到这个集群

非第一次选举 当我们源leader

出现故障时,其他节点选举新的leader,先比较epoch(任期),在比较事务id,服务器id,最大胜出

kafka

是一个消息队列(MQ),大数据实时处理 解耦 数据缓冲 流量削峰 异步处理

发布/订阅模式 主要是观察者模式 一对多 消费完之后不会清楚数据

部署kafka 首先需要部署 zookeeper集群,在zookeeper集群基础上再安装kafka应用(中间件),节点(服务器数量>=3奇数台)

生产者推送数据到kafka集群需要通过zookeeper确定kafka的位置,消费者消费的数据在哪里,也要根据存储在zookeeper上offset来确定偏移量记录上的一条消费的数据位置,以便在故障恢复的时候可以接着下一跳数据继续消费

几个kafka服务器几个broker,生成推送的数据到topic(主题)当中,topic可以被分区多个partition,一个partition可以有多个replication,replication可以是一个leader和多个follower,leader负责数据的读写,follower负责备份复制,消费者面向topic进行数据消费

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值