zabbix简介及部署

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

一、zabbix简介

   zabbix是一款企业级的监控解决方案,它可以通过SNMP、zabbix专用agent、简单的系统管理及网络工具来监控对象,收集信息,并将收集到的信息存储在数据库中,通过即时绘制来进行数据展示,并根据阈值,超出及报警,并具有联动处理的功能,即利用脚本进行服务重启等操作。在众多监控工具中,zabbix是有专用的agent端监控工具,在windowns,linux等众多操作系统,都有其专用的agent端。在网络设备,如路由器,交换机中,zabbix使用SNMP协议或SSH协议来实现监控功能。zabbix支持的数据存储有mysql和pgsql数据库。综上所述,zabbix可谓是功能众多,在应用领域,zabbix自1.8版本后,广为流传。

自动化监控架构图如下:

    wKiom1g9VDOxpyBHAAOKiJXRfys038.png

 (引自马哥文档)

zabbix可监控的对象:

            设备/软件
                设备:服务器,路由器,交换机,IO系统
                软件:OS,网络,应用程序
            意外状况:
                主机down机,服务不可用,主机不可达
            严重事件故障:
                磁盘满了,数据节点down掉了
            主机性能指标:

                CPU,内存使用情况

            趋势:时间序列数据(一般用于数据展示阶段)

zabbix包含的组件:

            zabbix-server
            zabbix-agent
            zabbix-web:GUI,用户实现zabbix设定和展示
            zabbix-proxy:分布式监控环境中的专用组件    

            zabbix-database:MYSQL,PGSQL(postgreSQL),Oracle,DB2,SQLite

zabbix的常用术语:
            主机(host):要监控的网络设备,可由IP或DNS名称指定
            主机组(host group):主机的逻辑容器,可以包含主机和模板,但同一个组内的主机和模板不能互相链接,主机组通常在给用户或用户组指派监控权限时使用
            监控项(item);一个特定监控指标的相关的数据,这些数据来自于被监控对象,item是zabbix进行数据收集的核心,没有item,将没有数据,相对某监控对象来说,每个item都由“key”进行标识
            触发器(trigger):一个表达式,用于评估某监控对象的某特定item内所接收到的数据是否在合理范围内,即阈值;接收到的数据量大于阈值时,触发器状态将从“ok”转变为“problem”,当数据量再次回归到合理范围时,其状态将从“problem”转换回“ok”;
            事件(event):即发生的一个值得关注的事情,例如触发器的状态转变,新的agent或重新上线的agent的自动注册等
            动作(action):指对于特定事件事先定义的处理方法,通过包含操作(如发送通知)和条件(何时执行操作)
            报警升级(escclction):发送警报或执行远程命令的自定义方案,如每隔5分钟发送一次警报,共发送5次等
            媒介(media):发送通知的手段或通道,如Email、Jabber或SMS等
            通知(notification):通过选定的媒介向用户发送的有关某事件的信息
            远程命令(remote command):预定义的命令,可在被监控主机处于某特定条件下时自动执行
            模板(template):用于快速定义被监控主机的预设条目集合,通常包含了item、trigger、graph、screen、application以及low-level discovery rule(较低级别的发现规则);模板可以直接链接至单个主机
            应用(application):一组item的集合
            web场景(web scennario):用于检测web站点可用性的一个或多个HTTP请求
            前端(frontend):zabbix的web接口
        
zabbix工作流程:

wKioL1g9joiRC_6hAAA6Vw0AYpI413.png-wh_50
            定义HostGroups之后定义Host,Host可以直接使用Template,Template中包含Graphs(展示),Triggers(报警),items(监控项);Host还可以先定义items,再在items上定义Triggers,Triggers其实是定义阈值,而当被监控数值超过了阈值,即触发Events(事件),由Events激活Actions(动作),由Action来执行脚本重启服务或其他报警操作,报警操作有邮件,电话等。maintenance定义了在业务上线,软硬件维护等时期,不产生报警;而items通过agent,snmp,internal,ipmi等方式收集信息。HostGroups的分组可以基于主机类型,地理位置,业务等方式。
            
zabbix服务器端主要进程:
            watchdog:监控server端所有进程
            poller:收取agent端数据
            httppoller:http专用的poller
            discoverer:自动发现agent,并加入监控
            alerter:报警
            housekeeper:内部管理
            pinger:通过ping操作探测主机是否在线
            escalator:报警升级
            timer:计时器
            nodewatcher:监控节点
            db_data_syncer:数据库数据同步器
            db_config_syncer:数据库配置同步器

zabbix的介绍完毕,下面咱们来部署zabbix。


二、zabbix部署

在安装zabbix之前,提前部署好LAMP或者LNMP。

部署LAMP详见   --->   编译部署LAMP

 

 zabbix可以在官网中获取,地址:http://www.zabbix.com/download

 zabbix官网为我们提供了三种安装方式:

    (1)源码编译安装      

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# tar -zxvf zabbix-3.2.1.tar.gz        
同时安装server和agent,并支持将数据放入mysql数据中,可使用类似如下配置命令:
. /configure  -- enable -server -- enable -agent --with-mysql -- enable -ipv6 --with-net-snmp --with-libcurl --with-ssh2
         
如果仅安装server,并支持将数据放入mysql数据中,可使用类似如下配置命令:
. /configure  -- enable -server --with-mysql --with-net-snmp --with-libcurl
         
如果仅安装proxy,并支持将数据放入mysql数据中,可使用类似如下配置命令:
. /configure  --prefix= /usr  -- enable -proxy --with-net-snmp --with-mysql --with-ssh2
         
如果仅安装agent,可使用类似如下配置命令:
. /configure  -- enable -agent
         
         
而后编译安装zabbix即可:
# make
# make install

    (2)配置yum源安装

1
2
3
4
5
[root@jymlinux ~] # rpm -ivh http://repo.zabbix.com/zabbix/2.4/rhel/6/x86_64/zabbix-release-2.4-1.el6.noarch.rpm
Retrieving http: //repo .zabbix.com /zabbix/2 .4 /rhel/6/x86_64/zabbix-release-2 .4-1.el6.noarch.rpm
warning:  /var/tmp/rpm-tmp .QBkmAF: Header V4 DSA /SHA1  Signature, key ID 79ea5ed4: NOKEY
Preparing...                 ########################################### [100%]
1:zabbix-release          ########################################### [100%]
1
2
3
4
5
6
[root@jymlinux ~] # yum clean all
已加载插件:fastestmirror, langpacks
正在清理软件源: base extras updates zabbix zabbix-non-supported
Cleaning up everything
Cleaning up list of fastest mirrors
[root@jymlinux ~] # yum makecache

     (3)rpm包下载安装


 2.配置zabbix-database,以mysql为例,可使用mysql和pgsql

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
MariaDB [(none)]> create database zabbix character  set  utf8;
MariaDB [(none)]> grant all on zabbix.* to  'zbxuser' @ 'localhost'  identified by  'zbxpass' ;
MariaDB [(none)]> grant all on zabbix.* to  'zbxuser' @ '192.168.%.%'  identified by  'zbxpass' ;
MariaDB [(none)]> flush privileges;
 
#连接测试
[root@jymlinux ~] # mysql -uzbxuser -hlocalhost -p
Enter password: 
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection  id  is 4
Server version: 5.5.50-MariaDB MariaDB Server
 
Copyright (c) 2000, 2016, Oracle, MariaDB Corporation Ab and others.
 
Type  'help;'  or  '\h'  for  help. Type  '\c'  to  clear  the current input statement.
 
MariaDB [(none)]> \q
Bye


3.安装zabbix

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
[root@jymlinux ~] # yum install zabbix zabbix-agent zabbix-get zabbix-sender zabbix-server zabbix-server-mysql zabbix-web zabbix-web-mysql
 
在httpd中生成zabbix-web的配置文件
[root@jymlinux ~] # cd /etc/zabbix/
[root@jymlinux zabbix] # ls
web  zabbix_agentd.conf  zabbix_agentd.d  zabbix_server.conf
[root@jymlinux zabbix] # service httpd start
Starting httpd: 
[root@jymlinux zabbix] # ls /etc/httpd/conf.d
php.conf  README  welcome.conf  zabbix.conf                #有了zabbix.conf这个文件
  
 
 
将zabbix导入数据库
[root@jymlinux zabbix] # cd /usr/share/doc/zabbix-server-mysql-2.4.8/
[root@jymlinux zabbix-server-mysql-2.4.8] # cd create/
[root@jymlinux create] # mysql zabbix < schema.sql      #注意导入顺序
[root@jymlinux create] # mysql zabbix < images.sql 
[root@jymlinux create] # mysql zabbix < data.sql 
#如果仅为proxy创建数据库,只导入schema.sql即可

 


4.配置zabbix-server

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
[root@jymlinux ~] # vim /etc/zabbix/zabbix_server.conf
### Option: DBHost
#       Database host name.
#       If set to localhost, socket is used for MySQL.
#       If set to empty string, socket is used for PostgreSQL.
#
# Mandatory: no
# Default:
# DBHost=localhost
DBHost=192.168.3.8                                    #填写连接的数据库服务器,默认是本机
 
### Option: DBUser
#       Database user. Ignored for SQLite.
#
# Mandatory: no
# Default:
# DBUser=
 
DBUser=zabbix
 
### Option: DBPassword
#       Database password. Ignored for SQLite.
#       Comment this line if no password is used.
#
# Mandatory: no
# Default:
# DBUser=
 
DBUser=zbxuser                                        #填写数据库用户名
 
### Option: DBPassword
#       Database password. Ignored for SQLite.
#       Comment this line if no password is used.
#
# Mandatory: no
# Default:
# DBPassword=
DBPassword=zbxpass                                    #填写数据库密码
 
 
其余常用修改选项
ListenIP=localhost  #数据库ip地址
AlertScriptsPath= /usr/local/zabbix/share/zabbix/alertscripts  #zabbix运行脚本存放目录



5.修改PHP时区

1
2
[root@jymlinux zabbix] # vim /etc/php.ini 
date .timezone =  'Asia/Chongqing'               #修改时区为重庆


到此,zabbix配置完毕,之后可以使用gui界面来定义对象等监控操作了



如有错误,敬请指正。



本文转自 元婴期 51CTO博客,原文链接:http://blog.51cto.com/jiayimeng/1868975

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8月前
|
监控 Linux 应用服务中间件
centos7 部署zabbix5 踩坑笔记
centos7 部署zabbix5 踩坑笔记
238 0
|
8月前
|
监控 Unix Windows
Zabbix【部署 04】 Windows系统安装配置agent及agent2
Zabbix【部署 04】 Windows系统安装配置agent及agent2
952 0
|
4月前
|
监控 前端开发 Linux
centos7系统安装部署zabbix5.0
【9月更文挑战第23天】在CentOS 7系统上部署Zabbix 5.0的步骤包括:安装MariaDB数据库及必要软件包,配置Zabbix仓库,设置数据库并导入Zabbix数据库架构,配置Zabbix服务器与前端参数,启动相关服务,并通过浏览器访问Web界面完成安装向导。
290 0
|
5月前
|
存储 弹性计算 监控
快速部署 Zabbix 社区版
Zabbix 是一款监控网络的众多参数以及服务器、虚拟机、应用程序、服务、数据库、网站、云等的健康和完整性的软件。Zabbix 使用灵活的通知机制,允许用户为几乎任何事件配置基于电子邮件的告警,以实现对服务器问题做出快速反应。Zabbix 基于存储的数据提供出色的报告和数据可视化功能。这使得 Zabbix 成为容量规划的理想选择。本文介绍如何通过计算巢快速部署 Zabbix 社区版。
快速部署 Zabbix 社区版
|
4月前
|
监控 Linux
Zabbix 5.0 LTS的agent服务部署实战篇
文章介绍了如何在CentOS 7.6操作系统上部署Zabbix 5.0 LTS版本的agent服务,包括配置软件源、安装agent、修改配置文件、启动服务,并在Zabbix web界面添加监控。
163 4
Zabbix 5.0 LTS的agent服务部署实战篇
|
4月前
|
监控 前端开发 数据库
Zabbix 5.0 LTS部署实战篇
这篇文章是关于Zabbix 5.0 LTS部署的详细教程,包括版本选择、服务器平台选择、安装步骤、数据库配置、前端安装以及修改时区和设置开机自启等内容。
348 1
Zabbix 5.0 LTS部署实战篇
|
8月前
|
监控 关系型数据库 MySQL
zabbix 简单介绍 及部署
zabbix 简单介绍 及部署
|
8月前
|
监控 关系型数据库 MySQL
基于AnolisOS8.6+PolarDB-X部署ZABBIX6.0
在AnolisOS-8.6-x86_64-minimal虚拟环境中,使用VirtualBox配置2 vCPU,4G RAM和60 vDisk,下载并安装PolarDB-X,包括libaio和ncurses-devel依赖。创建polarx用户,设置权限和目录结构,编写my.cnf配置文件,然后初始化并启动PolarDB-X。接着安装ZABBIX 6.0,创建数据库、用户及权限,导入数据,并编辑Zabbix配置文件以匹配PolarDB-X。最后,重启相关服务,启用并检查状态,通过指定IP访问Zabbix Web界面,注意初始账号密码为Admin / zabbix。
|
监控 Ubuntu Shell
用shell脚本部署zabbix
用shell脚本部署zabbix
200 1
|
8月前
|
监控 Java 数据库
Zabbix【部署 05】 Docker部署Zabbix Server Agent Agent2 Web interface及 Java-Gate-Way(详细启动脚本及踩坑记录)不定时更新
Zabbix【部署 05】 Docker部署Zabbix Server Agent Agent2 Web interface及 Java-Gate-Way(详细启动脚本及踩坑记录)不定时更新
618 0

推荐镜像

更多