【分布式应用】Zabbix——安装

news/2024/7/8 7:49:54

目录

第一章zabbix概述

1.1.什么是监控概念

1.2.zabbix概述

1.3.zabbix 主要特点

1.4.zabbix主要功能

1.5.zabbix运行机制

1.6.zabbix 监控原理

1.7zabbix的架构,数据流向以及原理在图中做总结

1.8.数据采集模式

1.9.zabbix监控模式

第二章.安装 部署 zabbix 服务端

2.1安装环境部署

2.2下载安装 zabbix 

2.3安装数据库

2.4修改配置文件

2.5游览器访问

总结

1.zabbix主要特点

2.zabbix运行机制

3.zabbix架构数据流向以及原理 见图中总结

4.zabbix工作原理 数据流向

5.zabbix监控模式

第三章部署zabbix 客户端(端口号10050)

3.1安装

3.2 将客户端加入服务端的监控主机中

总结


第一章zabbix概述

1.1.什么是监控概念

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

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

Zabbix :: The Enterprise-Class Open Source Network Monitoring Solution

1.2.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 等信息的收集。
 

1.3.zabbix 主要特点

免费开源

自动发现服务与网络设备分布式

可以监视应用层以及web集中管理功能

安全认证

监视结果通过email通知运维 (管理员)

1.4.zabbix主要功能

cpu负载

内存使用

磁盘使用

网络状态

端口监视

日志监视

中间件监视

插件开发自定义

1.5.zabbix运行机制

zabbix server(收集数据展示界面,监控端) 和zabbix agent(被监控端,收集服务器信息,通过协议发给server端;可以在很多平台使用,比如windows)

zabbix server    通过 B/S 模式在 Web 端展示和配置

zabbix agent     通过 C/S 模式采集数据   端口号10050

在Linux可以监控windows server 现阶段版本2012   2016   2019 

在生产中如果有大量设备通过域控进行管理

1.6.zabbix 监控原理

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

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

1.7zabbix的架构,数据流向以及原理在图中做总结

zabbix-client  架构                     服务端与客户端               小型架构
zabbix-proxy-client架构             zabbix分布式架构          中型架构
zabbix-master-node-client架构                                         大型架构

 

 

1.8.数据采集模式

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

1.9.zabbix监控模式

1.主动模式:agent像server发起连接

2.被动模式:server向aqent发起连接

第二章.安装 部署 zabbix 服务端

2.1安装环境部署

zabbix-server 内存至少 2G,推荐 4G; 

如果是编译安装要先安装LNMP       zabbix       LAMP        zabbix两种架构,yum安装不需要

systemctl stop firewalld

setenforce 0

hostnamectl set-hostname zbx-server

2.2下载安装 zabbix 

获取 zabbix 的下载源
rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm 

//更换 zabbix.repo 为阿里源
cd /etc/yum.repos.d


sed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' zabbix.repo

yum clean all && yum makecache

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

//安装SCL(Software Collections),便于后续安装高版本的 php,默认 yum 安装的 php 版本为 5.4,版本过低,zabbix 5.0 版本对 php 版本最低要 7.2.0 版本。SCL 可以使得在同一台机器上使用多个版本的软件,而又不会影响整个系统的依赖环境。软件包会安装在 /opt/rh 目录下。

yum install -y centos-release-scl 

/修改 zabbix-front 前端源,安装 zabbix 前端环境到 scl 环境下
vim zabbix.repo
......
[zabbix-frontend]
......
enabled=1          #开启安装源
......

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

2.3安装数据库

安装 zabbix 所需的数据库
yum install -y mariadb-server mariadb

systemctl enable --now mariadb

mysql_secure_installation         #初始化数据库,并设置密码,如 abc123
 

这里用的是mysql数据库,登录不需要密码

添加数据库用户,以及 zabbix 所需的数据库信息
mysql -u root -p                     # 登录不需要密码

CREATE DATABASE zabbix character set utf8 collate utf8_bin;


GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';


flush privileges;

//导入数据库信息
rpm -ql zabbix-server-mysql                                   #查询 sql 文件的位置

zcat /usr/share/doc/zabbix-server-mysql-5.0.24/create.sql.gz | mysql -uroot -p“” zabbix                    这里版本不对需要修改,不然没这个文件

2.4修改配置文件

修改 zabbix server 配置文件,修改数据库的密码
vim /etc/zabbix/zabbix_server.conf 
......
DBPassword=zabbix                    #124行,指定 zabbix 数据库的密码

//修改 zabbix 的 php 配置文件
vim /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf
......
php_value[date.timezone] = Asia/Shanghai        #24行,取消注释,修改时区

 这边很明显有错误,已修改。

//启动 zabbix 相关服务
systemctl restart zabbix-server zabbix-agent httpd rh-php72-php-fpm
systemctl enable zabbix-server zabbix-agent httpd rh-php72-php-fpm

2.5游览器访问

浏览器访问:http://192.168.233.186/zabbix       点击下一步,设置数据库的密码 zabbix

(由于登陆时清除了网页缓存,登陆时已经进去了,暗部操作即可)


设置文件界面:点击左边菜单栏的【User settings】,【Language】选择 Chinese(zh_CN),再点击 Update 等安装完成后,默认的登录账号和密码为:Admin/zabbix新。

//解决 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

总结


1.zabbix主要特点

免费开源

自动发现服务与网络设备分布式

可以监视应用层以及web集中管理功能

安全认证

监视结果通过emai1通知运维(管理员)

主要功能

cpu负载

内存使用

磁盘使用

网络状态端口监视

日志监视

中间件监视

插件开发自定义


2.zabbix运行机制


zabbix server 和 zabbix aqent (端口: 10050)

C/s                通过B/S模式在web端展示和配置


3.zabbix架构数据流向以及原理 见图中总结


zabbix-client                架构
zabbix-proxy-client 

zabbix-master-node-client


4.zabbix工作原理 数据流向

abbix在进行监控时,zabbix客户端要安装在被监控设备上,负责定期收集数据,并将其发送给Zabbix服务端:

zabbix服务端安装在监控设备上,其将zabbix客户端发送的数据存储在我们的数据库中,zabbixweb根据数据在前端进行展示和绘图


5.zabbix监控模式

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

第三章部署zabbix 客户端(端口号10050)

3.1安装

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

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

systemctl disable --now firewalld  

setenforce 0  

hostnamectl set-hostname zbx-agent01  ​

 

##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  ​  

cd /etc/yum.repos.d  

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 配置文件  

vim /etc/zabbix/zabbix_agent2.conf  

......  

Server=192.168.41.45                         #80行,指定 zabbix 服务端的 IP 地址  

 

ServerActive=192.168.41.45               #120行,指定 zabbix 服务端的 IP 地址   

Hostname=zbx-agent01                      #131行,指定当前 zabbix 客户端的主机名  ​

 

 

##6、启动 zabbix-agent2  

systemctl start zabbix-agent2  

systemctl enable zabbix-agent2  ​  

netstat -natp | grep zabbix  

tcp6       0      0 :::10050               :::*             LISTEN    4381/zabbix_agent2  

​  ​  

 

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

yum install -y zabbix-get                    #服务端,安装 zabbix 主动获取数据的命令,get指令

 ​  

 

zabbix_get -s '192.168.233.100' -p 10050 -k 'agent.ping'  1            

 #服务端对客户端进行连通性测试,返回1表示连通  ​  

 

zabbix_get -s '192.168.41.46' -p 10050 -k 'system.hostname'  zbx-agent01    

#返回客户端的主机名说明正常连通

 

3.2 将客户端加入服务端的监控主机中

在 Web 页面中添加 agent 主机

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

【主机名称】设置成 zbx-agent01  

【可见的名称】设置成 zbx-agent01-192.168.233.100  

【群组】选择 Linux server  

【Interfaces】的【IP地址】设置成 192.168.233.100  ​

 

 

2.再点击上方菜单栏【模板】  【Link new tamplates】搜索 Linux ,选择 Template OS Linux by Zabbix agent  点击 【添加】

 

 

成功完成 

总结

zabbix工作原理(工作流程):

zabbix-agent 客户端,部署在被监控的对象主机上,负责定期收集监控数据,发送给zabbix-server 端;

zabbix-server 收到数据后会将数据存储在数据库中。

用户可以基于zabbix-web可以在WEB UI界面中查看展现的数据图像,以及进行相关的配置管理 用户还可以在WEBUI界面中设置监控项的触发器,如被监控的数据指标超过触发器设定的阈值,会进行发送通知信息或者一些应急操作指令。

zabbix的实际使用请见下一篇博客


http://lihuaxi.xjx100.cn/news/1026353.html

相关文章

李宏毅教程系列——增强学习

目录 0. 强化学习wiki 1. 介绍 2. Exploration vs Exploitation 探索与开发 3. 各类最优化方法 3.1 Brute force猛兽蛮力法(暴力搜索) 3.2 Value function estimation(价值函数估计) 3.2.1 Monte Carlo methods 蒙特卡洛方…

苹果AirPods耳机推送新固件更新,TWS耳机与Find My可实现智能防丢

苹果推送 iOS / iPadOS 16.5 Beta 2 更新的同时,原本还为 AirPods 耳机推送了固件更新 5E133。苹果在临时撤回之后,再次向用户推送了本次更新, 苹果官方表示当你的 AirPods 在充电且在 iPhone、iPad 或 Mac 的蓝牙通信范围内时,…

JavaScript对象类型之Array及Object

目录 一、Array (1)语法 (2)API 二、Object (1)语法 (2)特色:属性增删 (3)特色:this (4)特色&#xf…

spring boot项目:实现与数据库的连接

步骤【写在前面】定义数据库连接信息:引入数据库驱动:创建数据源:创建JdbcTemplate:编写DAO层:使用Service注解标注Service层:使用RestController注解标注Controller层:示例代码:app…

Flink CDC入门案例

由于Flink CDC是基于日志的方式,因此需要开启MySQL的binlog日志。 开启binlog日志的配置如下 #1.编辑MySQL的配置文件 vim /etc/my.cnf #添加如下内容 [mysqld] log-binmysql-bin # 开启 binlog binlog-formatROW # 选择 ROW 模式 server_id1 # 配置 MySQL replact…

第十九章 弹性池塘

“我?你是想问我的师父是谁?嘻嘻,你猜?谅你也猜不到,我师父是大酒鬼克雷季特!你还没见过这位受人爱戴的老爷爷对吧?嘻嘻,这样说他似乎有些不厚道。等你明天上他的课时就知道了。他的…

传统图像处理——颜色迁移

转自知乎:https://zhuanlan.zhihu.com/p/267832794,仅供学习。 利用一张图片的颜色去修改另一张图片的颜色风格。 原理是利用颜色空间的正交化,即更改某个颜色,不会影响到其它属性。这里的色彩迁移的论文则是使用了LAB空间(RGB颜…

ESP32学习笔记09-ADC多通道采集 dma方式传输

9. ADC多通道采集 dma方式传输 9.1 DIG SAR ADC 控制器 9.1.1特点 高性能。时钟更快,因此采样速率实现了大幅提升。支持多通道扫描模式。每个 SAR ADC 的测量规则可见样式表。扫描模式可配置为 单通道模式双通道模式交替模式。扫描可由软件或 I2S 总线发起。支持 DMA,扫描完…