zabbix

zabbix是什么(重点)

  • 定义:
  • 组成:
  • zabbix server可以通过SNMP,zabbix
  • zabbix agent
  • zabbix监控原理
    • URL监控部署在系统中,包含常见的五个程序:
  • 主要特点:
  • zabbix工作原理
  • 服务端
    • 1、关闭防火墙,修改主机名
    • 2、获取 zabbix 的下载源
    • 3、更换 zabbix.repo 为阿里源,安装zabbix-server-mysql、zabbix-agent和SCL
    • 4.修改zabbix-front前端源,安装zabbix前端环境到scl环境下
    • 5.安装zabbix所需要的数据库
    • 6.添加数据库用户,以及zabbix所需要数据库信息
    • 7.查询已安装的zabbix-server-mysql的文件列表,找到sql.gz文件位置
    • 8、修改 zabbix-server 配置文件/etc/zabbix/zabbix_server.conf,修改数据库的密码。
    • 9.修改zabbix的php配置文件,/etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf
    • 10.启动zabbix相关服务
    • 11.浏览器访问http://192.168.109.1/zabbix
    • 12、解决zabbix-server Web页面中乱码问题
  • 部署zabbix客户端(端口号10050)
    • 1.关闭防火墙、修改主机名
    • 2.服务端和客户端都配置时间同步
    • 3.客户端配置时区,与服务器保持一致
    • 4.设置zabbix的下载源,安装zabbix-agent2
    • 5.修改agent2配置文件,/etc/zabbix/zabbix_agent2.conf
    • 6.启动zabbix-agent2
    • 7.在服务端验证zabbix-agent2的连通性
  • 总结:

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工作原理

zabbix_第1张图片

采用了两种模式(面试)

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

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

监控架构

zabbix分布式架构

server-client架构

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

master-node-client架构

master和node其中一个挂了,没什么关系
zabbix_第3张图片
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

zabbix_第4张图片

2、获取 zabbix 的下载源

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

zabbix_第5张图片

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_第6张图片
安装zabbix-server-mysql和zabbix-agent

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

zabbix_第7张图片
安装SCL(Software Collections),便于后续安装高版本php

yum install -y centos-release-scl

zabbix_第8张图片

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

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

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

zabbix_第9张图片

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

zabbix_第10张图片

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

yum install -y mariadb-server mariadb

zabbix_第11张图片
zabbix_第12张图片
zabbix_第13张图片

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;

zabbix_第14张图片

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

zabbix_第15张图片
zabbix_第16张图片

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

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

zabbix_第17张图片

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

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

zabbix_第18张图片

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

zabbix_第19张图片

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

zabbix_第20张图片
zabbix_第21张图片
zabbix_第22张图片
zabbix_第23张图片
zabbix_第24张图片
zabbix_第25张图片
zabbix_第26张图片
zabbix_第27张图片
zabbix_第28张图片
zabbix_第29张图片
zabbix_第30张图片

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_第31张图片
zabbix_第32张图片

部署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

zabbix_第33张图片

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

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

zabbix_第34张图片

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

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

zabbix_第35张图片

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

zabbix_第36张图片

yum install -y zabbix-agent2

zabbix_第37张图片

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

vim /etc/zabbix/zabbix_agent2.conf

zabbix_第38张图片

6.启动zabbix-agent2

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

zabbix_第39张图片

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

yum install -y zabbix-get

zabbix_第40张图片

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

zabbix_第41张图片
2.3将客户端加入服务端的监控主机中

zabbix_第42张图片
zabbix_第43张图片
zabbix_第44张图片
zabbix_第45张图片
zabbix_第46张图片
zabbix_第47张图片
zabbix_第48张图片
zabbix_第49张图片

总结:

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进行数据消费

你可能感兴趣的:(zabbix,php,开发语言)