• 一、Zabbix 简述

    • 1.监控功能
  • 2.Zabbix 工作原理

  • 3.Zabbix 重要组件

  • 4.Zabbix 进程

  • 5.Zabbix 监控架构

  • 二、部署 Zabbix 监控平台

    • 1.修改 Zabbix 的 YUM 源
  • 2.安装 Zabbix 监控软件

  • 3.安装 Mariadb 数据库

  • 4.编辑 Zabbix 主配置文件

  • 5.安装 Zabbix Web 接口

  • 6.Zabbix Web 平台基本配置

  • 三、部署被监控端

    • 1.监控路由器
  • 2.添加并监控 Linux 主机

  • 3.添加并监控 Win7 主机

一、Zabbix 简述

==============================================================================

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

1.监控功能


  • 主机的性能监控、网络设备性能监控、数据库性能监控、多种告警方式、详细的报表图表绘制。

  • 监控主机 Zabbix 有专用的 Agent,可以监控 Linux,Windows,FreeBSD 等。

  • 监控网络设备 Zabbix 通过 SNMP 协议,SSH(不多用)。

1)监控对象

  • 设备:服务器,路由器、交换机。

  • 软件:OS,网络,应用程序。

2)主机性能指标监控

  • 故障监控:Down 机,服务不可用,主机不可达。

2.Zabbix 工作原理


  1. Zabbix Agent 需要安装到被监控的主机上,它负责定期收集各项数据,并发送到 Zabbix Server 端;

  2. Zabbix Server 将数据存储到数据库中,Zabbix Web 根据数据在前端进行展现和绘图。

这里 Agent 收集数据分为主动和被动两种模式:

  • 主动:Agent 请求 Server 获取主动的监控项列表,并主动将监控项内需要检测的数据提交给 Server/Proxy。

  • 被动:Server 向 Agent 请求获取监控项的数据,Agent 返回数据。

3.Zabbix 重要组件


  • Zabbix Server:负责接收 Agent 发送的报告信息的核心组件,所有配置、数据统计、数据操作都是由它组织进行。

  • Database Storage:负责存储所有的配置信息以及收集的数据。

  • Web Interface:是 Zabbix 的 GUI 接口,通常情况下与 Server 运行在同一台主机上。

  • Pxory:属于可选组件,常用于分布式监控环境中,代理 Server 收集部分数据,然后转发到 Server,可以减轻 Server 的压力。

  • Agent:部署在被监控主机上,用于采集本地数据。

4.Zabbix 进程


默认情况下 Zabbix 包含五个程序:

  • Zabbix_Agent:客户端守护进程,此进程用于收集被监控端的数据,如 CPU 负载、内存、硬盘使用情况等。

  • Zabbix_Get:Zabbix 工具是单独使用的命令。Get 是在 Server 或者 Proxy 端执行获取远程远程客户端信息的命令,主要用于排错。

  • Zabbix_Sender:用于发送数据给 Server 或者 Proxy,通常用于耗时比较长的检查。

  • Zabbix_Server:Zabbix 服务端守护进程。Agent Get Sender Server Proxy Java_Gateway 的数据最终都是提交到 Server。

  • Zabbix_Proxy:Zabbix 代理守护进程。功能类似 Server,唯一不同的是它只是一个中转站,需要把收集到的数据主动(或被动)地提交到 Server 上。

  • Zabbix_Java_Gateway(需额外安装):顾名思义 Java 网关,类似 Agent,但是只用于 Java 方面。需要特别注意的是,它只能主动获取数据,而不能被动获取数据。它的数据最终会提交到 Server 或者 Proxy

5.Zabbix 监控架构


在实际生产坏境中,Zabbix 根据网络环境、监控规模等外界因素分为三种架构:Server-Client(直接连接)、Master-Node-Client(Node 架构)、Server-Proxy-Client(Proxy 架构),如图:

在这里插入图片描述

1)Server-Client 架构

  • Server-Client 架构是 Zabbix 最简单的架构,监控机和被监控机之间不经过任何代理;

  • 直接在 Zabbix ServerZabbix Agent 之间进行数据交互,适用于网络比较简单,设备比较少的监控环境。

2)Master-Node-Client 架构

  • Master-Node-Client 架构是 Zabbix 最复杂的架构,适用于跨网络、跨机房、设备较多的大型环境。

  • 每个 Node 同时也是一个 Server 端,Node 下面可以接 Proxy,也可以直接 接 Client

  • Node 有自己的配置文件和数据库,其要做的是将配置信息和监控数据向 Master 同步。

  • Master 发生故障或损坏, Node 可以保证架构的完整性。

3)Server-Prxoy-Client 架构

  • ProxyServerClient 之间沟通的桥梁,Proxy 本身没有前端,而且其本身并不存放数据;

  • 只是将 Agent 发来的数据暂时存放,而后再提交给 Server

  • 该架构经常是和 Master-Node-Client 架构做比较的架构,一般适用于跨机房、跨网络的中型网络架构的监控。

二、部署 Zabbix 监控平台

===================================================================================

准备工作:

| 主机 | 操作系统 | 网卡 | IP地址 |

| — | — | — | — |

| Zabbix | CentOS7 | 桥接,VM2 | DHCP,192.168.100.110 |

| 被监控端1(CentOS7) | CentOS7 | VM2 | 192.168.100.120 |

| 被监控端2(Win7) | Win7 | VM2 | 192.168.100.130 |

在这里插入图片描述

[root@localhost ~]# wget https://mirrors.aliyun.com/zabbix/zabbix/4.4/rhel/7/x86_64/zabbix-release-4.4-1.el7.noarch.rpm

[root@localhost ~]# ls

[root@localhost ~]# rpm -ivh zabbix-release-4.4-1.el7.noarch.rpm

[root@localhost ~]# cd /etc/yum.repos.d/

[root@localhost yum.repos.d]# ls

在这里插入图片描述

1.修改 Zabbix 的 YUM 源


[root@localhost yum.repos.d]# vim zabbix.repo

将文件所有的:

baseurl=http://repo.zabbix.com/zabbix/4.4/rhel/7/$basearch/

改为:

baseurl=http://mirrors.tuna.tsinghua.edu.cn/zabbix/zabbix/4.4/rhel/7/$basearch/

在这里插入图片描述

2.安装 Zabbix 监控软件


[root@localhost ~]# yum -y install zabbix-server-mysql zabbix-web-mysql zabbix-agent

3.安装 Mariadb 数据库


  • Zabbix Web 需要数据库。在 Mariadb 中创建数据库 Zabbix,授权用户 Zabbix 管理,增强安全性。

[root@localhost ~]# cat < /etc/yum.repos.d/zhangsan.repo

[zhangsan]

name=zhangsan

baseurl=file:///mnt

enable=1

gpgcheck=0

END

[root@localhost ~]# mv /etc/yum.repos.d/CentOS-* /root/

[root@localhost ~]# mount /dev/cdrom /mnt/

mount: /dev/sr0 写保护,将以只读方式挂载

[root@localhost ~]# yum -y install mariadb-server mariadb

在这里插入图片描述

[root@localhost ~]# systemctl start mariadb

[root@localhost ~]# mysqladmin -uroot password ‘123456’

[root@localhost ~]# mysql -uroot -p123456

MariaDB [(none)]> create database zabbix character set utf8 collate utf8_bin;

MariaDB [(none)]> grant all privileges on zabbix.* to zabbix@localhost identified by ‘123123’;

MariaDB [(none)]> exit

导入数据库脚本:

[root@localhost ~]# zcat /usr/share/doc/zabbix-server-mysql-4.4.10/create.sql.gz | mysql -uzabbix -p123123 zabbix

4.编辑 Zabbix 主配置文件


  • 指定数据库名称、用户、密码。

[root@localhost ~]# vim /etc/zabbix/zabbix_server.conf

根据行号改为如下:

91 DBHost=localhost

100 DBName=zabbix

116 DBUser=zabbix

124 DBPassword=123123

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Linux运维工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Linux运维知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加VX:vip1024b (备注Linux运维获取)
img

为了做好运维面试路上的助攻手,特整理了上百道 【运维技术栈面试题集锦】 ,让你面试不慌心不跳,高薪offer怀里抱!

这次整理的面试题,小到shell、MySQL,大到K8s等云原生技术栈,不仅适合运维新人入行面试需要,还适用于想提升进阶跳槽加薪的运维朋友。

本份面试集锦涵盖了

  • 174 道运维工程师面试题
  • 128道k8s面试题
  • 108道shell脚本面试题
  • 200道Linux面试题
  • 51道docker面试题
  • 35道Jenkis面试题
  • 78道MongoDB面试题
  • 17道ansible面试题
  • 60道dubbo面试题
  • 53道kafka面试
  • 18道mysql面试题
  • 40道nginx面试题
  • 77道redis面试题
  • 28道zookeeper

总计 1000+ 道面试题, 内容 又全含金量又高

  • 174道运维工程师面试题

1、什么是运维?

2、在工作中,运维人员经常需要跟运营人员打交道,请问运营人员是做什么工作的?

3、现在给你三百台服务器,你怎么对他们进行管理?

4、简述raid0 raid1raid5二种工作模式的工作原理及特点

5、LVS、Nginx、HAproxy有什么区别?工作中你怎么选择?

6、Squid、Varinsh和Nginx有什么区别,工作中你怎么选择?

7、Tomcat和Resin有什么区别,工作中你怎么选择?

8、什么是中间件?什么是jdk?

9、讲述一下Tomcat8005、8009、8080三个端口的含义?

10、什么叫CDN?

11、什么叫网站灰度发布?

12、简述DNS进行域名解析的过程?

13、RabbitMQ是什么东西?

14、讲一下Keepalived的工作原理?

15、讲述一下LVS三种模式的工作过程?

16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?

17、如何重置mysql root密码?

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
img

么区别,工作中你怎么选择?

7、Tomcat和Resin有什么区别,工作中你怎么选择?

8、什么是中间件?什么是jdk?

9、讲述一下Tomcat8005、8009、8080三个端口的含义?

10、什么叫CDN?

11、什么叫网站灰度发布?

12、简述DNS进行域名解析的过程?

13、RabbitMQ是什么东西?

14、讲一下Keepalived的工作原理?

15、讲述一下LVS三种模式的工作过程?

16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?

17、如何重置mysql root密码?

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-MlRSMFPg-1712648756205)]

Logo

技术共进,成长同行——讯飞AI开发者社区

更多推荐