Zabbix 监控软件(一)

        通常我们服务搭建成功 但不清楚服务器的运行状况,这时候就需要会使用监控系统查看服务器状态以及网站流量指标,利用监控系统的数据去了解上线发布的结果,和网站的健康状态。

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

一、zabbix 简述

1.1 zabbix 是什么?

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

除了zabbix,还有哪些其它的监控软件?

  • cacti  网络和绘图
  • nagios  网络监控
  • ganglia  分布式监控系统


●zabbix 由 2 部分构成,zabbix server 与可选组件 zabbix agent。通过 C/S 模式采集数据,通过 B/S 模式在 Web 端展示和配置。


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


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

通过 C/S 模式 采集数据 ,通过 B/S模式(浏览器/服务器模式) 在 web端 展示 和配置

zabbix server  10051端口,zabbix agent  10050端口

1.2 zabbix的主要特点

  • 安装配置简单  学习成本比较低
  • 支持多语言 包括中文
  • 免费开源
  • 自动发现服务器与网络设备
  • 分布式监控以及web集群中的管理功能
  • email 功能通知    短信   语音 微信 钉钉

1.3 监控哪些主要功能

CPU 负载   内存使用  磁盘使用率  网络状态   端口监视  日志监视  插件开发自定义

1.4 zabbix 运行机制

zabbix-agent 数据采集 ---->  zabbix-server (数据分析/报警) ---->  数据库(数据存储) ---->  zabbix-web(数据展示)

zabbix的监控对象

硬件监控、系统监控、网络监控、java 监控、应用服务监控、数据库监控、url监控、vmware 监控虚拟机运行状况

监控模式
  • 被动监控 :server向 agent发起连接
  • 主动监控 :agent向 server 发起连接

1.5 zabbix 监控原理

        zabbix agent安装在被监控的主机上,zabbix agent负责定期收集客户端本地各项数据,并发送至 zabbix server 端,zabbix server 收到数据后,将数据存储到数据库中,用户基于 Zabbix WEB 可以看到数据在前端展现图像。

        当 zabbix 监控某个具体的项目, 该项目会设置一个触发器阈值,当被监控的指标超过该触发器设定的阈值,会进行一些必要的动作,动作包括:发送信息(邮件、微信、短信)、发送命令(shell 命令、reboot、restart、install 等)。

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

1.7 zabbix 的各种架构

server-client 第一种架构

        也就是zabbix最简单的架构,监控机器和被监控机器之间不经过任何处理,直接由zabbix-server和zabbix-client之间进行数据交换。适用于网络比较简单,尽量在局域网内,设备比较少的监控环境使用

server-proxy-client 架构

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

Master-Node-Client 架构

        Master-Node-Client该架构是Zabbix最复杂的监控架构,适用于跨网络跨机房设备多的大型环境。每个Node同时接一个Sever端,Node下面可以接Proxy端,也可以直接连接Client,Node有自己的配置文件和数据库,其要做的是将配置信息和监控数据向Master进行数据同步,Master故障损坏对Node其下架构的完整性无任何影响

注意:node挂了proxy会收集node所管理的客户端的数据并暂存到proxy中,然后把数据发送到server端保存。

安装 zabbix 5.0

部署 zabbix 服务端

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

1.关闭防火墙

systemctl disable --now firewalld
setenforce 0

2.更改主机名

hostnamectl set-hostname zbx-server

3.获取 zabbix 的下载源

zabbix官网:Zabbix:企业级开源监控解决方案

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

4. 更换 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

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

yum install -y centos-release-scl 

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

vim /etc/yum.repos.d/zabbix.repo......
[zabbix-frontend]
......
enabled=1          #开启安装源
......yum install -y zabbix-web-mysql-scl zabbix-apache-conf-scl

7. 安装 zabbix 所需的数据库

yum install -y mariadb-server mariadbsystemctl enable --now mariadbmysql_secure_installation         #初始化数据库,并设置密码,如 abc123

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

mysql -u root -pabc123CREATE DATABASE zabbix character set utf8 collate utf8_bin;
GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';
flush privileges;解释:
CREATE DATABASE zabbix character set utf8 collate utf8_bin;
创建名为zabbix的数据库,并设置其字符集为utf8,排序规则为utf8_bin。GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';
授予用户权限。给用户名为zabbix的MySQL用户分配了对数据库zabbix中的所有对象(即. *表示所有表)的所有
权限(即all关键字表示包括但不限于SELECT、INSERT、UPDATE、DELETE、CREATE、DROP等全部权限)。'zabbix'@'%' 表示该用户可以从任何主机(%通配符代表任意IP地址或主机名)登录到MySQL服务器。IDENTIFIED BY 'zabbix' 表示该用户的密码是zabbix。flush privileges;
刷新MySQL服务器的权限

9. 导入数据库信息

先退出数据库 exit + 回车 或 ctrl + crpm -ql zabbix-server-mysql 		#查询 sql 文件的位置zcat /usr/share/doc/zabbix-server-mysql-5.0.42/create.sql.gz | mysql -uroot -pabc123 zabbix解压Zabbix服务器MySQL版本的初始数据库脚本,并使用MySQL的root用户将脚本中的SQL命令执行到名为zabbix 的数据库中,以完成Zabbix数据库的初始化配置。

10. 修改 zabbix server 配置文件,修改数据库的密码

vim /etc/zabbix/zabbix_server.conf 
......
DBPassword=zabbix					#124行,指定 zabbix 数据库的密码zabbix是密码,要与GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';中一样。

11. 修改 zabbix 的 php 配置文件

vim /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf
......
php_value[date.timezone] = Asia/Shanghai		#24行,取消注释(那个;号是注释),修改时区

12.启动 zabbix 相关服务

systemctl restart zabbix-server zabbix-agent httpd rh-php72-php-fpm
systemctl enable zabbix-server zabbix-agent httpd rh-php72-php-fpm

浏览器访问:http://192.168.80.7/zabbix

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

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

在某些Linux发行版中,为了增加安全性或者符合个人习惯,可能会在Shell配置文件(如 ~/.bashrc 或系统级
别的配置文件)中定义一个 cp 的别名,例如 alias cp='cp -i'。这样做后,每次当你仅输入 cp 命令时,实
际上是按 -i 参数来运行,这个参数会让 cp 在覆盖已存在的文件前给出提示。你使用\cp 表示使用原本意思,在复制时不会问你是否覆盖。

部署 zabbix 客户端

zabbix 5.0 版本采用 golang 语言开发的新版本客户端 agent2 。
zabbix 服务端 zabbix_server 默认使用 10051 端口,客户端 zabbix_agent2 默认使用 10050 端口。

1.关闭防火墙

systemctl disable --now firewalld
setenforce 0

2.修改用户名

hostnamectl set-hostname zbx-agent01

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

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

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

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

date

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

rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpmsed -i 's#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' /etc/yum.repos.d/zabbix.repoyum install -y zabbix-agent2
无网环境去官网下载。

6. 修改 agent2 配置文件

vim /etc/zabbix/zabbix_agent2.conf
......
Server=192.168.80.7			#80行,指定 zabbix 服务端的 IP 地址
ServerActive=192.168.80.7		#125行,指定 zabbix 服务端的 IP 地址
Hostname=zbx-agent01			#136行,指定当前 zabbix 客户端的主机名

7.启动 zabbix-agent2

systemctl start zabbix-agent2
systemctl enable zabbix-agent2

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

yum install -y zabbix-get				#安装 zabbix 主动获取数据的命令[root@zbx-server opt]#zabbix_get -s '192.168.80.11' -p 10050 -k 'agent.ping'
1
#在服务端 判断能否收集到客户端的数据,1代表成功,0是失败。[root@zbx-server opt]#zabbix_get -s '192.168.80.11' -p 10050 -k 'system.hostname'
zbx-agent01

9. 在 Web 页面中添加 agent 主机

点击左边菜单栏【配置】中的【主机】,点击【创建主机】
【主机名称】设置成 zbx-agent01
【可见的名称】设置成 zbx-agent01-192.168.80.11
【群组】选择 Linux server
【Interfaces】的【IP地址】设置成 192.168.80.11

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/989.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

R语言入门:“Hellinger“转化和“normalize“转化(弦转化)的公式表示与R代码实现

1、写在前面 vegan包中的decostand()函数为群落生态学研究提供了一些流行的(和有效的)标准化方法。有关decostand()函数标准化的一些标准化方法可以看我的另一篇笔记:R语言入门:vegan包使用decostand()函数标准化方法 由于在网络上没有找到关于这两个转…

互联网技术知识点总览——操作系统知识点框架图

简介 本文对操作系统的知识点整体框架进行梳理和分享如下:

【问题解决】Fatal error “unsafe repository (‘git目录名‘ is owned by someone else)“

问题复现 近期升级了 Git v2.37.0,发现在git bash进入git目录执行git命令时出现错误:Fatal error "unsafe repository (git目录名 is owned by someone else)",无法使用git做一些操作。 问题解决 两个方法:降级到v2.…

避障型激光传感器SE-0522/0526/0533/1022/1026/1033应用与接线说明

避障型激光传感器SE-0522/0526/0533/1022/1026/1033是根据飞行时间(TOF 测量原理)运行,在极高的同步时钟下,以 均匀的时间间隔发射激光,激光光束遇到物体时 会反射回来,扫描传感器接收到反射 的光束后&…

正式项目的验收文件模板

了解了!下面是一个更完整和专业的研发项目验收报告的Word文档模板的详细内容,你可以将其复制到Word中并进行相应的格式调整以符合你的需求: 项目验收报告 项目名称:[输入项目名称] 项目编号:[输入项目编号] 项目负责人…

docker安装clickhouse数据库

1.创建目录 mkdir -p /data/clickhouse/data mkdir -p /data/clickhouse/conf mkdir -p /data/clickhouse/log2.拉取镜像 docker pull clickhouse/clickhouse-server3.创建临时容器 docker run -d --rm --name clickhouse-server --ulimit nofile262144:262144 clickhouse/c…

2024 发布Maven项目到中央仓库

注册sonatype账号 Maven中央仓库并不支持直接发布jar包,sonatype是其指定的第三方仓库之一,发布到此的项目会被定时同步到中央仓库 官方教程地址:https://central.sonatype.org/register/central-portal/ 访问网址:https://centra…

新项目应该选mongodb还是postgresql?

文章目录 MongoDBPostgreSQL大数据处理时的优势对比实际使用经验 选择MongoDB还是PostgreSQL作为新项目的数据库,主要取决于项目的具体需求、数据模型、应用场景以及团队熟悉程度等因素。下面将从几个关键角度对两者进行对比分析。 MongoDB 数据模型:Mo…

开发工具——postman使用教程详解

一、概念 1、Postman是一款功能强大的网页调试与发送网页HTTP请求的Chrome插件,Postman分为Postman native app和Postman Chrome app两个版本。目前Chrome app已停止维护,官方不推荐使用该版本。 2、官网下载地址:http://www.getpostman.com…

softmax回归的从零开始实现

1.初始化模型参数 import torch from IPython import display from d2l import torch as d2l batch_size 256 train_iter, test_iter d2l.load_data_fashion_mnist(batch_size) num_inputs 784 num_outputs 10 W torch.normal(0, 0.01, size(num_inputs, num_outputs), r…

【数据结构】复习题(二)

Hello!大家好,这一篇数据结构复习题是我上个学期复习的时候写的(刚刚在草稿箱发现了!)有一些题目过程都是配了图片的,希望对正在复习数据结构的宝宝们有帮助哦!(还有一个数据结构复习题(一)可以…

代码随想录算法训练营第60天|84.柱状图中最大的矩形

代码随想录算法训练营第60天|84.柱状图中最大的矩形 |有了之前单调栈的铺垫,这道题目就不难了。 84.柱状图中最大的矩形 https://programmercarl.com/0084.%E6%9F%B1%E7%8A%B6%E5%9B%BE%E4%B8%AD%E6%9C%80%E5%A4%A7%E7%9A%84%E7%9F%A9%E5%BD%A2.html class Soluti…

Ant Design Pro + springboot实现文件上传功能

前端代码 <a-upload:fileList"fileList":beforeUpload"beforeUpload":customRequest"customRequest" ><a-button style"margin-left: 50px" type"primary" ref"btn">导入配置文件 </a-button>…

代码随想录算法训练营第三十二天| 122.买卖股票的最佳时机II ,55. 跳跃游戏,45.跳跃游戏II

目录 题目链接&#xff1a;122.买卖股票的最佳时机II 思路 代码 题目链接&#xff1a;55. 跳跃游戏 思路 代码 题目链接&#xff1a;45.跳跃游戏II 思路 代码 总结 题目链接&#xff1a;122.买卖股票的最佳时机II 思路 每天可以重复买卖&#xff0c;所以只需要计算每…

Spring JdbcTemplate基本使用

1. JdbcTemplate概述 它是spring框架中提供的一个对象&#xff0c;是对原始繁琐的JdbcAPI对象的简单封装。spring框架为我们提供了很多的操作模板类。例如:操作关系型数据的JdbcTemplate和HibermateTemplate&#xff0c;操作nosql数据库的RedisTemplate&#xff0c;操作消息队…

p2949(简单反悔贪心)

题目链接 #include<bits/stdc.h> using namespace std; const int N2e520; using ll long long; long long ans; struct node{int x,y;bool operator < (node p) const{return x<p.x; //按截至时间从小到大排序 } }a[N]; long long ti; int main() {map<int,in…

Hadoop学习总结(Hive的远程服务、数据模型操作、数据操作)

在启动hive时要先启动Hadoop。 在SecurityCRT 或者在 Xshell 进行虚拟机链接 &#xff08;这里使用Xshell &#xff09; 一、Hive 的管理 1、CLI 方式 &#xff08;1&#xff09;启动 Hive 直接输入 hive &#xff08;2&#xff09;退出 直接输入以下一条命令&#xff0…

预付费电表管理系统:WEB端的高效解决方案

1.系统概述 预付费电表管理系统&#xff0c;尤其是基于WEB端的版本&#xff0c;是一种现代化的电力管理工具&#xff0c;旨在提高能源效率&#xff0c;优化电费支付流程&#xff0c;并提供实时的用电数据监控。它通过互联网技术&#xff0c;使得用户能够在线充值、查询电量、远…

如何排查oracle连接数不足问题

最近oracle数据库莫名其妙的连接不上&#xff0c;plsql连接报错&#xff0c;sqlplus终端打开时提示ora-00020错误&#xff0c;下面记录一下本次问题的解决过程。 1.sqlplus 登录数据库 show parameter processes;–当前默认配置的process是多少。 select count(*) from v$pr…

开源全方位运维监控工具:HertzBeat

HertzBeat&#xff1a;实时监控系统性能&#xff0c;精准预警保障业务稳定- 精选真开源&#xff0c;释放新价值。 概览 HertzBeat是一款深受广大开发者喜爱的开源实时监控解决方案。它以其简洁直观的设计理念和免安装Agent的特性&#xff0c;实现了对各类服务器、数据库及应用…