Zabbix监控

news/2025/1/8 20:49:49/

Zabbix监控

  • 1.Zabbix监控概述
    • 1.1 zabbix是什么
    • 1.2 zabbix监控原理
    • 1.3 Zabbix 6.0新特性
    • 1.4 Zabbix 6.0功能组件
    • 1.5 Zabbix与prometheus区别对比
  • 2. 部署Zabbix6.0
    • 2.1 安装Nginx+PHP
    • 2.2 部署Mariadb数据库
    • 2.3 安装zabbix Server服务端
    • 2.4 部署Web前端,进行访问
    • 2.5 部署客户端zabbix-agent2
  • 3. 总结

1.Zabbix监控概述

作为一个运维,需要会使用监控系统查看服务器系统性能、应用服务状态和网站流量指标等,利用监控系统的数据去了解网站上线发布的结果和健康状态。
在这里插入图片描述

1.1 zabbix是什么

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

1.2 zabbix监控原理

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

1.3 Zabbix 6.0新特性

(1)Zabbix server高可用防止硬件故障或计划维护期的停机

  • 原生选择加入HA群集配置
  • 定义一个或多个备用节点
  • 实时监控Zabbix server群集节点的状态
  • 不需要外部工具即可将Zabbix server配置为HA群集模式

(2)Zabbix 6.0 LTS新增Kubernetes监控功能,可以在Kubernetes系统从多个维度采集指标

  • Kubernetes节点和pods的自动发现和监控
  • 无代理方式采集Kubernetes pods和节点的信息
  • 获取Kubernetes节点主机高水平信息

1.4 Zabbix 6.0功能组件

Zabbix Server:端口(10051)
zabbix服务端守护进程,是Zabbix软件的核心组件,Zabbix Agent向其报告可用性、系统完整性信息和统计信息
Zabbix Server也是存储所有配置信息、统计信息和操作信息的核心存储库
Zabbix Server也是Zabbix监控系统的告警中心。在监控的系统中出现任何异常,将发出通知给管理员
基本Zabbix Server的功能分解为三个不同的组件:Zabbix server、Web前端、数据库
Zabbix的所有配置信息都存储在Server和Web前端进行交互的数据库中。例如,当你通过Web前端(或者API)新增一个监控项时, 它会被添加到数据库的监控项表里。然后,Zabbix server以每分钟一次的频率查询监控项表中的有效项,接着将它存储在Zabbix server中的缓存里。 这就是为什么Zabbix前端所做的任何更改需要花费两分钟左右才能显示在最新数据段的原因。

数据库
所有配置信息以及Zabbix采集到的数据都被持久存储在数据库中
可以支持MySQL、PostgreSQL、Oracle、DB2、TimescaleDB等多种关系和时序性数据库中。

Web界面
Web界面是Zabbix Server的一部分,用于实现展示和配置的界面。通常(但不一定)和Zabbix server运行在同一台物理机器上。
基于Apache/Nginx + PHP实现,早期只支持LAMP架构,从Zabbix5.0 开始支持LNMP 。

Zabbix Agent:端口(10050)
客户端守护进程,部署在被监控目标上,用于主动监控本地资源和应用程序,并将收集的数据发送给Zabbix Server。从 Zabbix5.0 开始支技 Zabbix Agent2 。

Zabbix Proxy
zabbix分布式代理守护进程,可以代替Zabbix Server采集性能和可用性数据。Zabbix Proxy在Zabbix的部署是可选部分。
Zabbix Proxy的部署可以很好的分担单个Zabbix Server的负载
通常监控大于500台主机时使用,需要进行分布式监控架构部署

Java Gateway
Zabbix要监控Tomcat服务或其它JAVA程序(比例 Elasticsearch、ZooKeeper),需要通过JMX端口,使用Java Gateway做为代理,才能从JAVA 程序中获取数据。
在这里插入图片描述

1.5 Zabbix与prometheus区别对比

在这里插入图片描述

2. 部署Zabbix6.0

###关闭和禁止防火墙开机自启功能
systemctl stop firewalld
systemctl disable firewalld
setenforce 0
sed -i 's/enforcing/disabled/' /etc/selinux/config

2.1 安装Nginx+PHP

(1)修改主机名为zbx-server

hostnamectl set-hostname zbx-server
su

(2)使用nginx在线源,安装nginx

cd /etc/yum.repos.d
rz -E
#nginx.repo
yum install -y nginx

在这里插入图片描述
(3) 安装PHP

curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
yum install -y epel-release
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
yum -y install php72w php72w-cli php72w-common php72w-devel php72w-embedded php72w-gd php72w-mbstring php72w-pdo php72w-xml php72w-fpm php72w-mysqlnd php72w-opcache php72w-ldap php72w-bcmath

在这里插入图片描述

(4) 修改nginx配置

vim /etc/nginx/conf.d/default.conf 
server {listen 80;server_name zbx.gzy.com;location / {root /var/www/zbx;index  index.php index.html index.htm;}location ~ \.php$ {fastcgi_pass 127.0.0.1:9000;fastcgi_index index.php;fastcgi_param SCRIPT_FILENAME /var/www/zbx$fastcgi_script_name;include fastcgi_params;}
}

在这里插入图片描述

在这里插入图片描述

(5) 修改php配置

vim /etc/php-fpm.d/www.conf
user = nginx
group = nginxvim /etc/php.ini
max_execution_time = 300		# 368行
max_input_time = 600			# 378行
post_max_size = 80M				# 656行
date.timezone = Asia/Shanghai	# 877行

在这里插入图片描述

(6) 创建目录和测试文件

###创建index.php文件的网页数据文件地址
mkdir -p /var/www/zbxvim /var/www/zbx/index.php
<?php
phpinfo();
?>

在这里插入图片描述

(7) 启动服务

systemctl restart nginx php-fpm.service
systemctl enable nginx php-fpm.service 
netstat -lntp | grep nginx
netstat -lntp | grep php

在这里插入图片描述

(8) 在/etc/hosts文件中添加本地域名解析,并使用浏览器进行验证访问

###在物理机中添加虚拟主机域名与IP地址的对应关系
C:\Windows\System32\drivers\etc\hosts
192.168.80.20 zbx.kgc.com###浏览器访问
http://zbx.gzy.com/index.php

在这里插入图片描述

在这里插入图片描述

2.2 部署Mariadb数据库

(1)配置Mariadb数据库的yum源

vim /etc/yum.repos.d/mariadb.repo
[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

(2)安装并启动mariadb数据库

yum install -y mariadb-server mariadb###启动数据库
systemctl  start  mariadb
systemctl  enable mariadb
netstat -lntp | grep mariadb

在这里插入图片描述
(3)初始化数据库

mysql_secure_installation
#分别输入回车 -> n -> Y (设置root密码:123) -> 后面一路Y###进入数据库
mysql -u root -p123

在这里插入图片描述
(4)创建zabbix数据库

#创建数据库并指定字符集
CREATE DATABASE zabbix character set utf8 collate utf8_bin;#创建zabbix数据库用户并授权
GRANT all ON zabbix.* TO 'zabbix'@'localhost' IDENTIFIED BY 'zabbix';
GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';
flush privileges;

在这里插入图片描述
(5)向数据库中导入zabbix数据

#上传源码包zabbix-6.0.13.tar.gz到/opt目录
cd /opt
rz -E
#zabbix-6.0.13.tar.gz
tar xf zabbix-6.0.13.tar.gz#按照顺序依次导入数据库
cd /opt/zabbix-6.0.13/database/mysql
mysql -uroot -p123 zabbix < schema.sql
mysql -uroot -p123 zabbix < images.sql
mysql -uroot -p123 zabbix < data.sql
mysql -uroot -p123 zabbix < double.sql
mysql -uroot -p123 zabbix < history_pk_prepare.sql

2.3 安装zabbix Server服务端

(1)安装依赖包,创建zabbix用户

yum install -y mysql-devel pcre-devel openssl-devel zlib-devel libxml2-devel net-snmp-devel net-snmp libssh2-devel OpenIPMI-devel libevent-devel openldap-devel libcurl-devel fping gcc gcc-c++ makeuseradd -s /sbin/nologin -M zabbix

在这里插入图片描述
(2)编译安装

cd /opt/zabbix-6.0.13/./configure \
--sysconfdir=/etc/zabbix/ \
--enable-server \
--with-mysql \
--with-net-snmp \
--with-libxml2 \
--with-ssh2 \
--with-openipmi \
--with-zlib \
--with-libpthread \
--with-libevent \
--with-openssl \
--with-ldap \
--with-libcurl \
--with-libpcremake install

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

(3)检查版本

zabbix_server --version

在这里插入图片描述

(4)修改zabbix server配置文件,修改数据库的密码

vim /etc/zabbix/zabbix_server.conf 
......
LogFile=/var/log/zabbix_server.log		#38行,指定zabbix日志路径
DBPassword=zabbix					#123行,指定在zabbix监控中,登录zabbix数据库的密码###创建/var/log/zabbix_server.log文件,并设置所属主用户为zabbix
touch /var/log/zabbix_server.log
chown zabbix.zabbix /var/log/zabbix_server.log

(5)准备systemctl服务管理文件

vim /usr/lib/systemd/system/zabbix-server.service
[Unit]
Description=Zabbix Server with MySQL DB
After=syslog.target network.target mysqld.service[Service]
Type=simple
ExecStart=/usr/local/sbin/zabbix_server -f
User=zabbix[Install]
WantedBy=multi-user.target

(6) 启动zabbix-server服务

systemctl start zabbix-server.service
systemctl enable zabbix-server.service
netstat -lntp | grep 10051			#zabbix_server默认监听10051端口

在这里插入图片描述

2.4 部署Web前端,进行访问

(1)将zabbix安装包下的目录文件,复制到nginx的网页目录/var/www/zbx下

cp -r /opt/zabbix-6.0.13/ui/* /var/www/zbx
chown -R nginx.nginx /var/www/zbx

在这里插入图片描述

(2)浏览器访问,验证测试

http://zbx.gzy.com/ 

【Default language】选择Chinese(zh_CN),点击下一步
在这里插入图片描述

在这里插入图片描述
【密码】输入zabbix,点击下一步
在这里插入图片描述
【Zabbix主机名称】输入Zabbix-监控;【默认时区】选择 Asia/Shanghai,点击下一步
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

安装完成后,默认的登录账号和密码为:Admin/zabbix

在这里插入图片描述

在这里插入图片描述

2.5 部署客户端zabbix-agent2

(1)将zabbix.repo在线源中的国际在线源,更换为aliyun镜像源

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.repo

(2)安装zabbix客户端,实现zabbix服务端自我监控

#zabbix 5.0 版本开始采用golang语言开发的新版本客户端agent2
yum install -y zabbix-agent2

在这里插入图片描述
(3)启动zabbix-agent2服务

systemctl start zabbix-agent2.service
systemctl enable zabbix-agent2.service
netstat -lntp | grep 10050			#客户端zabbix_agent2默认监听10050端口

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

(4)解决 zabbix-server Web页面中文乱码问题
在这里插入图片描述

\cp -f /usr/share/fonts/wqy-microhei/wqy-microhei.ttc /var/www/zbx/assets/fonts/DejaVuSans.ttf

(5)刷新浏览器页面

在这里插入图片描述

3. 总结

虚拟机

Windows  VMWare workstation   个人版
VMWare Sphere + ESXI        商用方案
KVM       基于Linux内核创建的虚拟机
XEN

云平台

公有云(方便、便宜)   *阿里云  华为云  腾讯云  青云  天翼云  移动云  联通云 AWS亚马逊云  google谷歌云  Azure微软云
私有云(安全)  openstack (KVM)
混合云

分布式应用

监控  zabbix  prometheus
日志  ELK->EFLK -> EFLFK
消息队列   Kafka + Zookeeper   
存储   Ceph GFS MFS

http://www.ppmy.cn/news/738405.html

相关文章

微信开发提示【防盗号或诈骗,请不要输入QQ密码】

微信开发提示【防盗号或诈骗&#xff0c;请不要输入QQ密码】&#xff0c;如下图 解决方案&#xff1a;设置业务域名

微信去除 防欺诈或盗号请不要输入qq密码 的方法

共需要三步 1.点击公共号设置 2.选中里面的功能设置 3.输入相应的域名

去除微信顶部的“防欺诈盗号,请勿支付或输入qq密码”

本文介绍如何去除微信顶部的“防欺诈盗号,请勿支付或输入qq密码”。或 “防欺诈或盗号&#xff0c;请不要输入qq密码”如图所示。 一、微信认证 目前只有已经通过微信认证的账号可以去除这个提示。在公众账号下左侧列表中找到微信认证&#xff0c;按照提示申请认证即可。 二、…

黑客是怎么盗取你的密码的?

一、猜测法 猜测法就是从用户的心理入手进行分析&#xff0e;从而破解出密码。掌握好该方法可以缩短破解时间&#xff0c;获得用户信息。这种方法破解都指黑客破解密码&#xff0c;而不是软件的注册破解。 用该方法时主要考虑以下一些心理原则。 使用姓氏的拼音作为密码 对中…

实现用户登录--微信扫码、账号密码

实现用户登录 一、微信扫码登录二、账号密码登陆 一、微信扫码登录 首先通过socket.io和服务器建立连接获取服务器返回的二维码地址通过qrcode把返回的地址生成二维码登入微信,使用手机进行扫码socket.io需要执行的事件 1&#xff09;connect连接成功的事件 2&#xff09;scan…

游戏里数据和表现的分离

大家好&#xff0c;我是阿赵   之前遇到有个朋友做游戏&#xff0c;遇到一个这样的问题&#xff1a;在一个即使战斗的游戏里面&#xff0c;客户端的表现经常会出现一些问题&#xff0c;比如血量不同步、角色位置不同步、瞬移、角色表现状态不对等。但游戏服务端非常肯定&…

数据库sql 根据身份证计算年龄段mysql、oracle

数据库sql根据身份证计算年龄段 mysql: SELECTage,count(*) numFROM(SELECTCASEWHEN TIMESTAMPDIFF(YEAR,DATE(substring(id_card,7,8)),CURDATE())<35 THEN 35岁以下WHEN TIMESTAMPDIFF(YEAR,DATE(substring(id_card,7,8)),CURDATE()) > 35AND TIMESTAMPDIFF(YEAR,DATE…

时间序列预测 | Matlab基于粒子群算法优化门控循环单元(PSO-GRU)的时间序列预测,PSO-GRU时间序列预测,单列数据集

文章目录 效果一览文章概述部分源码参考资料效果一览 文章概述 时间序列预测 | Matlab基于粒子群算法优化门控循环单元(PSO-GRU)的时间序列预测,PSO-GRU时间序列预测,单列数据集。 优化参数为学习率,隐藏层节点个数,正则化参数,要求2020b及以上版本&#