码迷,mamicode.com
首页 > 其他好文 > 详细

zabbix详解(三)

时间:2016-02-19 14:33:20      阅读:1371      评论:0      收藏:0      [点我收藏+]

标签:linux   监控   zabbix   

 

zabbix网络发现

网络发现有什么用?比如小军有100台服务器,不想一台台主机去添加,这时就可以使用网络发现功能自动添加了,前提条件是所有服务器都已经安装了agentsnmpServer端就可以扫描配置好的ip段,自动添加host,自动给host link 模板、自动添加到主机组里等。网络发现功能让我们能更快速的部署zabbix、简化zabbix管理,并且在经常变动的环境里面也不需要花太多的精力。

 

zabbix网络发现基于如下信息

  • ip范围

  • 可用的外部服务(FTP,SSH,WEB,POP3,IMAP,TCP

  • 来自zabbixagent的信息

  • 来自snmp agent的信息

 

网络发现由两个阶段组成:discoveryactions

1discovery

zabbix 定期扫描网络发现规则中的ip范围,每个规则中定义了一组需要检测的服务,在这些ip范围内一一扫描,每次检测到servicehost,都会生成一个discovery事件,事件如下:

时间条件
serviceupzabbix检测到可用服务
servicedownzabbix无法检测到service
hostup某个ip上至少有一个服务是up状态
hostdown所有服务都无响应
servicediscovered一个服务首次被发现或者在维护后从新归队
servicelost服务在up之后又丢失了
hostdiscovered一个host首次被发现或者在维护后从新归队
hostlost 一个hostup之后又丢失了


2Actions

zabbix所有action都是基于发现事件,例如:

  • 发送通知

  • 添加/移除主机

  • 启用/禁用主机

  • 添加主机到组

  • 从组中移除主机

  • 主机link模板/unlink模板

  • 执行远程脚本命令

 

创建主机主机名的定义

discovery 发现主机事件产生之后,将会执行action添加主机等操作。首先server端通过ip番解析主机名(如果失败了,不会重新尝试),如果解析成功了,那么zabbix将会使用这个主机名,否则直接使用ip地址。如果主机名同名呢?比如都叫ngx-server,那么第一台主机名会定义为ngx-server,第二台为ngx-server_2,第三台为ngx-server_3,以此类推。

 

创建主机主机接口的添加

主机接口添加规则如下:

服务检测-例如成功检测到一个SNMP服务,那么创建snmp接口

如果主机同时对agentsnmp请求作出响应,那么会同时创建这两种接口

通过哪个接口发现主机,哪个接口就作为默认接口,其余作为附加接口

如果一开始只响应agent的检测,那么它只会创建agent接口。如果后面响应了snmp检测,那么它又会增加snmp接口

 

3)配置案例

先配置一个discovery rules , Configuration -> Discovery-> creatediscovery rule

技术分享


然后再添加对应的action,Configuration -> Actions (右上角的Event source 选择 Discovery)-> create action

技术分享

技术分享

技术分享

除了添加主机,还可以link Template等操作



zabbix自动注册

网络发现是好用,但它要不断的扫描特定网段,所产生的流量,耗费的资源也是很大的。自动注册可以解决这个问题,server不用再扫描特定网段,只需设置好规则,等待特定网段的主机自动向server注册即可。

配置过程:

1)定义agent端,编辑/etc/zabbix/zabbix-agent.conf

    serverActive=192.168.61.154主动模式服务器地址设置

     Server=192.168.61.154被动模式服务器地址设置

     Hostname=a4.com主机名

     ListenIP=192.168.61.140设置为本机某特定IP

     ListenPort=默认即可

     HostMetadata=a4.com 唯一标识一个主机

     HostMetadataItem=itemkey,

     一般使用system.uname。在客户端用一个itemkey 获得一个数据,发送给服务器端注册,一般就用system.uname获得主机名

 

2server端配置

Configuration -> Actions (右上角的Eventsource 选择Auto registration) -> create action

 其余设置和网络发现的action设置一样

 

 

zabbix LLD: Low Level Discovery

 

1)客户端配置

编写获取需要的数据的脚本放/etc/zabbix-agent.d/scripts下(该路径为自定义)

自定义参数文件到/etc/zabbix/zabbix_agentd.conf.d/ ,调用上面的脚本

 

2)服务器端配置

新建模板template-> (该模板下)新建应用application(这个可以不建,主要用于把下面的item分类) -> (该应用下)添加 item prototype (用于为发现的项目自动添加需要的监控项目,key里使用定义好的变量名,方便对应多种不同的名字)-> 创建trigger(关联刚才定义的trigger,还可以继续添加graph图形

 

 

zabbix proxynode

serveragent在不同的机房,并且有大量主机的时候,在各机房配置一个proxy是最好的选择。因为不用proxy直接配置各主机直接访问异地机房server的话,需要开发多条防火墙规则,也带来了安全隐患,配置了proxy的话,只需要开放一台proxy主机即可。

 

nodeproxy的区别:

node是一个完整的节点,可以完全独立配置各itemaction等和运行,自身有数据库保留收到到的agent数据。proxy只是负责收集agent的数据发送给server端,并且不保留数据

一般千台以下的机器,配置proxy即可,使用方便。

下面简单介绍proxy的安装与配置

 

1zabbix proxy的安装(需要先配置epel源)

         yum -y zabbix-proxy

                   zabbix-proxy-mysql

                   zabbix-agent (一般proxy也是要被服务器端监控的,所以也会安装agent

                   zabbix-sender

                   zabbix

 

2)创建mysql数据库(mysql的安装请参考站内文章)

        createdatabase zabbix_proxy character set utf8;

         grantall on zabbix_proxy.* to zbxuser@‘172.16.%.%‘ identified by ‘zbxpass‘;

         flushprivileges;

 

3)导入数据

       mysqlzabbix_proxy < /usr/share/doc/zabbix-proxy-mysql-2.4.5/create/schema.sql

         rpm -qlzabbix-proxy-mysql可找到这个sql位置)

 

4)配置zabbix-proxy

        vim/etc/zabbix/zabbix_proxy.conf

         server=172.16.100.6指明服务器地址

         Hostname=proxy1

         DBHost=172.16.100.7本机

         DBName=zabbix_proxy

         DBUser=zbxuser

         DBPassword=zbxpass

         HeartbeatFrequency=60  每隔60秒探测一下服务器的活动状态

         ConfigFrequency=3600  每隔3600秒到服务器端拉取相关配置

         DataSenderFrequency=1 每隔1秒就发送一次数据到服务器端,发送数据后会自动删除的,所以本地保存数据量很少

 

5)启动服务

        servicezabbix-proxy start

         ss-tnl 查看服务是否正常运行

 

6)服务器端的配置

         administrator-> proxies -> create proxy

         proxymode 的选择,Active 为主动拉取配置,Passive 为服务器端把配置推送过去

         创建好之后,以后新创建Host页面Monitoredby proxy 里就可以选择刚才的proxy

技术分享

技术分享

zabbix详解(三)

标签:linux   监控   zabbix   

原文地址:http://dengxi.blog.51cto.com/4804263/1743320

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!