zabbix入门知识

zabbix入门知识

zabbix中文手册
https://www.zabbix.com/documentation/3.4/manual/

1.zabbix介绍

    Zabbix 是一个企业级的分布式开源监控方案。
    Zabbix是一款能够监控各种网络参数以及服务器健康性和完整性的软件。
    Zabbix使用灵活的通知机制,提供了出色的报告和数据可视化功能
    Zabbix支持主动轮询和被动捕获。
    Zabbix基于Web的前端页面进行访问。
    Zabbix是免费的。
    特点:
        数据收集
        灵活的阀值定义
        高度可配置化的告警
        实时图表绘制
        Web监控功能
        丰富的可视化选项
        历史数据存储
        配置简单
        使用模板
        网络发现
        简洁的Web界面
        Zabbix API
        权限管理系统
        功能强大并易于扩展的监控代理
        二进制代码
        为复杂环境准备

2.zabbix系统架构图

1250974-20171128085303237-579091834.png
1250974-20171128085349909-1712951394.png
1250974-20171128114251847-801416087.png

3.zabbix的组件

    zabbix agent:部署在被监控主机上,负责收集本地数据并发往server端或porxy端。
    zabbix server:负责接收agent发送的报告信息的核心组件,所有配置信息、统计数据及操作数据都由其组织进行。
    zabbix database:用于存储所有zabbix的配置信息、监控数据的数据库。
    zabbix web:zabbix的web界面,通过web界面管理zabbix的配置以及查看zabbix相关的监控信息,可以单独部署在独立的服务器上,是server的一部分,通常是在一台物理机上,若使用使用SQLite则必须在一台上。
    zabbix proxy:用于分布式监控环境中,zabbix proxy某程度上相当于server端,完成局部区域内的信息收集,最终统一发往server端。可帮server分担负载压力。
    zabbix数据流:
        为了创建一个监控项用于采集数据,必须先创建一个主机。转换到Zabbix功能的其他部分,你必须先有一个监控项来创建触发器,你必须有一个触发器来创建动作。 因此,如果你想收到X服务器CPU负载过高的告警,你必须先为X服务器创建一个主机实体并关联一个用于对CPU进行监控的监控项,然后如果CPU负载太高便会激活触发器,接着会执行一个动作,给你发送告警邮件。虽然看起来有很多步骤,但是使用模板的话可以会很简单。同时,这个设计可以创建一个非常灵活的配置。

4.zabbix支持的通讯协议

    理论上,zabbix能够监控几乎所有与业务相关的硬件资源。但是,能监控的前提是能相互间稳定通信。而zabbix支持的协议如下。
    agent:通过专用的代理程序进行监控,与常见的master/agent模型类型。若支持的话,优先选用agent。
    ssh、telnet:通过远程控制协议进行通信。
    SNMP:simple network management protocol,通过snmp协议进行监控,大部分网络设备都支持这种协议,与常见的master/agent模型类型,一般是在这些设备中内置有snmp的agent。
    IPMI:通过IPMI接口进行监控,来监控对象的物理特征,如电压,温度等。
    JMX:java management extensions,通过jmx监控jvm虚拟机。

5.zabbix的工作模式

    被动(passive)模式和主动(active)模式
    工作模式是对于agent端来说的。
    当agent端将采集完的数据主动发往server端的模式为主动模式。
    当agent端等待server端来垃圾数据的模式为被动过模式。
    主动模式与被动模式在agent端并不冲突,可以同时存在。
    agent端使用zabbix_sender工具测试能否向server端发数据,server端使用zabbix_get工具测试能否从agent端拉取数据。

6.zabbix的监控过程

    zabbix agent部署在被监控的主机上,由agent采集数据并报告给负责监控的中心主机,中心主机就是master/agent中的master;
    负责监控的中心主机为zabbix server,server将从agent端接收信息并存储到zabbix database中;
    管理员是从zabbix web支持的web GUI上查看各种监控信息的,而zabbix web是有php编写,所以依赖与LAMP环境;
    zabbix server和zabbix web都需要与zabbix database相互通信来获取数据。
    当监控规模非常庞大时,就需要用到分布式监控,使用zabbix proxy作为代理来接收agent的提交的数据信息,然后将数据统一发送给zabbix server处理,在局部proxy就相当于server。

7.zabbix常用术语

    主机 (host):要监控的网络设备,用IP或DNS名表示
    主机组 (host group):主机的逻辑组;它包含主机和模板。一个主机组里的主机和模板之间并没有任何直接的关联。通常在给不同用户组的主机分配权限时候使用主机组。
    监控项 (item):要接收的主机的特定数据,一个度量数据,某个监控指标。
    键(key):想要获取监控项对应的数据,就需要通过某个key去获取,可以把key当然调用命令的对应的命令别名。
    触发器 (trigger):一个被用于定义问题阈值和“评估”监控项接收到的数据的逻辑表达式。当接收到的数据高于阈值时,触发器从“OK”变成“Problem”状态。当接收到的数据低于阈值时,触发器保留/返回一个“OK”的状态。
    事件 (event):单次发生的需要注意的事情,例如触发器状态改变或发现有监控代理自动注册
    异常 (problem):一个处在“异常”状态的触发器
    动作 (action): 一个对事件做出反应的预定义的操作,由操作(例如发出通知)和条件(当时操作正在发生)组成
    升级 (escalation): 一个在动作内执行操作的自定义场景; 发送通知/执行远程命令的序列
    媒介 (media):发送告警通知的手段;告警通知的途径
    通知 (notification):利用已选择的媒体途径把跟事件相关的信息发送给用户
    远程命令 (remote command):一个预定义好的,满足一些条件的情况下,可以在被监控主机上自动执行的命令
    模版 (template):一组可以被应用到一个或多个主机上的实体(监控项,触发器,图形,聚合图形,应用,LLD,Web场景)的集合,模版的任务就是加快对主机监控任务的实施;也可以使监控任务的批量修改更简单。模版是直接关联到每台单独的主机上。
    应用 (application):一组监控项组成的逻辑分组
    web 场景 (web scenario):利用一个或多个HTTP请求来检查网站的可用性
    前端 (frontend):Zabbix提供的web界面
    Zabbix API:Zabbix API允许你使用JSON RPC协议来创建、更新和获取Zabbix对象(如主机、监控项、图形和其他)信息或者执行任何其他的自定义的任务
    Zabbix server:Zabbix软件实现监控的核心程序,主要功能是与Zabbix proxies和Agents进行交互、触发器计算、发送告警通知;并将数据集中保存等
    Zabbix agent:一个部署在监控对象上的,能够主动监控本地资源和应用的程序
    Zabbix proxy:一个帮助Zabbix Server收集数据,分担Zabbix Server的负载的程序

8.zabbix安装

1)配置仓库

    wget http://repo.zabbix.com/zabbix/3.4/rhel/7/x86_64/zabbix-release-3.4-2.el7.noarch.rpm
    rpm -ivh zabbix-release-3.4-2.el7.noarch.rpm(这是个配置仓库的安装包,会自动仓库)
    配置好仓库后,使用yum install来进行安装

2)zabbix server的安装

    yum install mariadb mariadb-libs mariadb-server zabbix-get zabbix-server-mysql.x86_64 ##(根据安装的数据库来选择包)                                     
    初始化zabbix数据库
        安装mysql数据
        创建zabbix数据库和用户
            MariaDB [(none)]> create database zabbix charset 'utf8';
            MariaDB [(none)]> grant all on zabbix.* to zabbix@'localhost' identified by 'xm1234';  ##这里设置的本地
            MariaDB [(none)]> flush privileges;
        初始化zabbix数据库
            通过rpm -ql zabbix-server-mysql找到create.sql.gz。
            解压得到create.sql脚本
                gunzip crete.sql.gz
            进行初始化
                mysql -uroot -p -Dzabbix < create.sql
            查看初始情况
                msyql -uroot -p
                MariaDB [(none)]> use zabbix
                MariaDB [zabbix]> show tables;
        根据需要配置/etc/zabbix-server.conf
            DBPassword=
        启动服务
            systemctl start zabbix-server

3)zabbix proxy的安装

    yum install zabbix-get zabbix-proxy-mysql.x86_64(根据安装的数据库来选择包)
    初始化配置和server差不多

4)zabbix web的安装

    yum install zabbix-web.noarch  zabbix-web-mysql ##依赖了很多包,包括httpd和php
    初始化
        创建lamp环境
            安装httpd和php(应该是在安装zabbix-web时,由依赖关系的原因以下都已安装,仅需要配置启动)
                yum install httpd php(php-fpm)php-mysql  maradb mariadb-libs mariadb-server
            启动httpd
                systemctl enable httpd
                systemctl start httpd
            启动maradb
            配置启动php
                两种方法,选其一。
                    1)modules:
                        yum install php php-mysql
                        vim /etc/httpd/conf/httpd.conf
                            在文件尾部加两行
                                AddType application/x-httpd-php .php
                                AddType application/x-httpd-php-source .phps
                            添加修改下面行
                                <IfModule dir_module>
                                    DirectoryIndex index.php index.html
                                </IfModule>
                        systemctl restart httpd
                    2)fastcgi:
                        yum install php-fpm php-mysql
                        vim /etc/httpd/conf/httpd.conf
                            在文件尾部加四行
                            AddType application/x-httpd-php .php
                            AddType application/x-httpd-php-source .phps
                            ProxyRequests Off 
                            ProxyPassMatch  ^/(.*\.php)$ fcgi://127.0.0.1:9000/app/httpd24/htdocs/$1
                            修改下面行
                            <IfModule dir_module>
                                DirectoryIndex index.php index.html
                            </IfModule>
                        systemctl restart httpd
                        systemctl start php-fpm

        配置/etc/httpd/conf.d/zabbix.conf
            vim  /etc/httpd/conf.d/zabbix.conf
                在文件头部添加
                    <VirtualHost 192.168.213.175:80>
                    servername zabbix-server
                    documentroot /usr/share/zabbix
                在文件尾部添加
                    </VirtualHost>
                修改
                    php_value date.timezone Asia/Shanghai
        重启httpd服务
    systemctl restart httpd

5)zabbix agent的安装

    agent 的运行
        Zabbix agent运行在被监控主机上。
        Zabbix agent在linux上以守护进程运行。
        Zabbix agent是是设计在非root账户下的。它会以其他任何非root用户启动的进程一样的方式运行。所以,您可以使用任意非root用户运行agent,且不会产生任何问题。
        如果您在’root’账户下运行,它将切换到硬编码的“zabbix”用户,该用户必须存在于您的系统上。如果您只想以’root’方式运行proxy,您必须在proxy配额文件里修改‘AllowRoot‘参数。
        Zabbix agent成功退出时退出码为0,异常则退出码为1。
    安装
        yum install zabbix-agent zabbix-sender
    配置
        vim /etc/zabbix/zabbix_agentd.conf|
        ##### Passive checks related  ##被动监控相关配置
            Server=IP1, IP2, ...##允许那台服务器拉取当前服务器的数据,用于实现基于ip的访问控制,若多个ip可用逗号隔开。
            ListenPort=10050 ##server端访问的监听端口,默认为10050
            ListenIP=0.0.0.0  ##本地监听的地址,默认为0.0.0.0,表示监听本地所有地址
            StartAgents=3  ##用于指定预生成的agent进程数量
        ##### Active checks related  ##主动监控相关配置,agent端主动向server周期性发送数据;
            ServerActive=IP1[:port], IP2[:port], ... ##信息推送到那台server服务器上,若多个ip可用逗号隔开。
            Hostname=Unique_HOSTNAME  ##指定当前主机名,用于server端的识别。
                必须与服务器配置的监控主机的主机名称保持一致;
    启动
        systemctl start zabbix-agent

9.zabbix web界面初始化

http://zabbix_web_ip/zabbix
    1)进入安装界面,点击next step
    2)进入check of pre-requisites,确认所有状态都为ok,点击next step
    3)进入configure DB connection,配置数据库类型,ip,端口,数据库名,用户密码,点击next step
        
        端口0表示使用默认端口3306
    4)进入zabbix server details,配置ip地址,端口,servername,添加name,这个name是你在/etc/httpd/conf.d/zabbix.conf中配置的servername,点击next step。
    5)进入pre-installation summary,检查,点next step
    6)进程如install,点击finish
        
    7)进入登录界面,默认username为admin,password为zabbix。
    8)登录后,可以修改英文为中文。
        若出现部分字体不能显示的情况
            1》确保/usr/share/zabbix/include/locales.inc.php 中的
                'zh_CN' => ['name' => _('Chinese (zh_CN)'), 'display' => true]
            2》上传你喜欢的字体文件到/usr/share/zabbix/fonts,文件是以.ttf结尾的,不是也修改成。
                编辑/usr/share/zabbix/include/defines.inc.php中的
                    define('ZBX_GRAPH_FONT_NAME',       'simkai'); // font file name
                    define('ZBX_FONT_NAME', 'simkai');
            确保simkai是你上传的字体文件的文件名

转载于:https://www.cnblogs.com/shenxm/p/7900571.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值