搭建Zabbix监控系统

本文介绍了Zabbix这款开源监控软件,包括其功能、重要组件(如ZabbixServer、Databasestorage、Webinterface、Proxy等)、监控结构,以及如何通过YUM在LAMP环境中部署和配置Zabbix服务器。
摘要由CSDN通过智能技术生成

简介

        在企业网络运维过程中,管理员必须随时关注各服务器和网络的运行状况,以便及时发现问题.尽可能减少故障的发生。当网络中的设备,服务器等数量较多时,为了更加方便、快捷地获得各种监控信息,通常会借助于一些集中监测软件。

一、Zabbix概述

        Zabbix 是一个基于Web界面的企业级开源监控套件,提供分布式系统监控与网络监视功能。具备主机的性能监控,网络设备性能监控,数据库性能监控,多种告警方式,详细报表、图表的绘制等功能。监测的对象可以是Linux或Windows服务器,也可以是路由器、交换机等网络设备,通过SNMP(Simple Network Management Protocol,简单网络管理协议)、Zabbix Agent、PING,端口监视等方法提
        供对远程网络服务器等监控,数据收集等功能,并提供通知机制使系统管理员可以快速定位、解决系统中存在的各种问题。目前,Zabbix最新版本为Zabbix 3.4,官方网站是http://www.zabbix.com。Zabbix 是免费的。Zabbix 遵循GPL(General Public License,通用公共许可证)版本2,这意味着它的源代码是可以自由分布的。Zabbix的商业版本是由Zabbix公司提供支持的。世界上很多大小不同的组织机构都依赖于Zabbix作为自己的一个主要的监控平台。尤其是现在很多互联网企业都在使用它。

1.zabbix重要组件

zabbix 主要由以下几个重要组件构成,具体作用如下。

  • Zabbix Server:负责接收Agent发送报告信息的核心组件,所有的配置,数据统计、数据操作都由它组织进行。
  • Database storage:负责存储所有的配置信息以及收集的数据。
  • Web interface:是zabbix的GUI接口,通常情况下与Zabbix Server运行在同一台主机上。
  • Pxory:属于可选组件,常用于分布式监控环境中,代理Server收集部分数据,然后转发到Server,可以减轻Server的压力。
  • Agent:部署在被监控的主机(客户端)上,负责收集被监控端主机的数据,如CPU、内存、数据库等数据,然后发送到Server 端或Proxy端。
2.zabbix进程

        默认情况下Zabbix包含五个程序:zabbix_agentd、zabbix_get、zabbix_sender、zabbix_server、zabbix_proxy,另外有个zabbix_java_gateway是可选的,需要另外安装。下面来分别介绍它们各自的作用。

  • zabbix_agentd:客户端守护进程,此进程用于收集被监控端的数据,如CPU负载、内存、硬盘使用情况等。
  • zabbix_get:zabbix工具是单独使用的命令。zabbix_get是在server或者proxy端执行获取远程客户端信息的命令,主要用于排错。例如,在server端获取不到客户端的内存数据时,我们可以使用zabbix_get获取客户端的内容的方式来做故障排查。
  • zabbix_sender:用于发送数据给 server或者proxy,通常用于耗时比较长的检查。很多检查非常耗时间,导致zabbix超时。于是我们在脚本执行完毕之后,可以使用sender主动提交数据。
  • zabbix_server:zabbix服务端守护进程。zabbix_agentd、zabbix_get、zabbix_sender、zabbix_proxy、zabbix_java_gateway 的数据最终都是提交到server。数据并不都是主动提交给zabbix_server的,也有被动提交数据的,即server主动去获取数据。
  • zabbix_proxy:zabbix代理守护进程。功能类似server,唯一不同的是它只是一个中转站,需要把收集到的数据主动(或被动)地提交到server上。
  • zabbix_java_gateway:在zabbix2.0之后引入的一个功能。顾名思义:Java网关,类似agentd,但是只用于Java方面。需要特别注意的是,它只能主动去获取数据,而不能被动获取数据。它的数据最终会提交到server或者proxy。
3.zabbix监控结构

        在实际生产环境中,Zabbix根据网络环境、监控规模等外界因素分为三种架构:server-client(直接连接)、master-node-client (Node架构)、server-proxy-client(Proxy 架构)。

1) server-client 架构

        server-client 架构是zabbix的最简单的架构,监控机和被监控机之间不经过任何代理,直接在zabbix server和zabbix agentd之间进行数据交互,适用于网络比较简单,设备比较少的监控环境。

2) master-node-client 架构

        master-node-client架构是Zabbix最复杂的监控架构,适用于跨网络、跨机房,设备较多的大型环境。每个node同时也是一个server端,node下面可以接proxy,也可以直接接client。node有自已的配置文件和数据库,其要做的是将配置信息和监控数据向master同步。当master发生故障或损坏,node可以保证架构的完整性。

3) server-proxy-client 架构

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

二、YUM安装Zabbix

        Zabbix 提供两种安装方式:YUM安装与编译安装。需要注意的是,由于CentOS官方YUM源中并不提供Zabbix软件包以及相关依赖包,因此,如果想用YUM安装Zabbix需要通过Zabbix官方源或第三方的YUM源实现。本节中我们通过YUM安装的方式学习Zabbix的安装及配置。
        Zabbix服务器需要LAMP环境或者LNMP环境,本例以YUM安装的LAMP环境为例,演示Zabbix监控服务器的部署方法。

实验环境

虚拟机2台centos7.9、网卡NAT模式数量 1、组件包 zabbix依赖包

设备

IP

备注

Centos01

192.168.19.10

Zabbix

Centos02

192.168.19.20

http yum 仓库

1.搭建zabbix yum仓库

安装httpd服务

[root@love ~]# yum -y install httpd

安装createrepo工具,生成yum源信息文件repo(把zabbix源放在html下)

[root@love ~]# yum -y install createrepo
[root@love ~]# cd /var/www/html/
[root@love html]# cd zabbix/
[root@love zabbix]# createrepo ./
[root@love zabbix]# systemctl start httpd
2.部署zabbix系统
配置yum源
[root@love ~]# vim /etc/yum.repos.d/local.repo
[zabbix]
name=Zabbix
baseurl=http://192.168.160.52/zabbix
enabled=1
gpgcheck=0

[DVD]
name=Centos7.9
baseurl=file:///mnt
enabled=1
gpgcheck=0

安装zabbix

[root@love ~]# yum -y install httpd vim net-tools
[root@love ~]# yum -y install mariadb mariadb-server zabbix-server-mysql zabbix-zgent zabbix-web
[root@love ~]# systemctl start mariadb

创建zabbix连接用户

[root@love ~]# mysql -u root
MariaDB [(none)]> create database zabbix character set utf8 collate utf8_bin;
Query OK, 1 row affected (0.00 sec)
MariaDB [(none)]> grant all privileges on zabbix.* to 'zabbix'@'localhost' identified by 'abc-123';
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> flush privileges;
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> exit
Bye

修改配置文件

Zabbix主配置文件
[root@love ~]# vim /etc/zabbix/zabbix_server.conf
DBPassword=abc-123

http加载初始化配置文件

[root@love ~]# vim /etc/httpd/conf.d/zabbix.conf
php_value date.timezone Asia/shanghai     取消注释 修改时区为 亚洲/上海

启动服务

[root@love ~]# systemctl enable httpd zabbix-server --now

进入网站配置页面

http://192.168.19.10/zabbix

用户:Admin

密码:zabbix

  • 18
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
课程目标     全面理解和掌握 Zabbix 监控系统的架构及运行原理,搭建和管理各种规模的Zabbix监控系统 课程简介         Zabbix是一个开源的企业级的监控解决方案。通过Zabbix可以监控IT基础设施的方方面面,包括硬件、操作系统、网络、虚拟化层、中间件和各种业务应用系统。用Zabbix几乎可以监控你想监控的任意数据。              本课程从Zabbix的介绍、安装开始,一步步带你深入Zabbix,通过学习你会:         1、掌握Zabbix各个组件的配置和管理。         2、掌握不同监控项的类型和配置方法,根据监控需求灵活配置监控项。         3、掌握网络发现、低级发现和主动式agent自动注册,实现自动化监控。         4、掌握模版、宏变量、触发器和告警通知的配置和高级的应用方法。         5、掌握图形、屏幕、拓扑图和仪表盘等数据可视化的方法,利用大屏可以实时的展示监控数据。         6、掌握Zabbix系统自身的维护、备份、升级、排障以及性能优化。         7、掌握Zabbix内部运行机制和Zabbix使用技巧,让zabbix更好的帮助你实现监控目标。                  本课程中还包含很多操作演示,比如像创建主机,创建监控项、触发器、图形、全局事件关联等,也介绍了微信和钉钉告警的配置方法。当你对Zabbix深入了解之后,面对层出不穷的新业务、新应用,你都能轻松自如的制定和提供相应的监控解决方案。 特别提示:官网的中文文档有些地方翻译的有问题,一定要以英文文档为准。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值