您的位置:首页 > 其它

zabbix 之 安装配置手册(全)

2017-12-07 10:12 706 查看

1.1.1.1. zabbix 概况

1.1.1.1.1. [b]zabbix 简介[/b]Zabbix是一个高度集成的网络监控解决方案,可以提供企业级的分布监控解决方案。
Zabbix通过C/S模式采集数据,通过B/S模式在web端展示和配置。
被监控端:主机通过安装agent方式采集数据,网络设备通过SNMP方式采集数据
Server端:通过收集SNMP和agent发送的数据,写入数据库(mysql,oracle等),再通过php-nginx或者php-apache在web前端展示。

1.1.1.1.2. [b]zabbix运行条件[/b]Server :zabbix server 对硬件的要求低,但需要运行在
LNMP(linux+nginx+mysql+php) 或者 LAMP(linux+apache+mysql+php) 环境下
Agent: 目前已有的agent 基本支持常见的OS,包含Linux, Solaris,SUN, Windows,等
SNMP: 支持各类常见的网络设备

1.1.1.1.3. [b]监控过程逻辑图[/b]



监控的zabbix server端进程如下:



1.1.1.1.4. [b]zabbix功能[/b]1 具备常见的商业监控软件所具备的功能(主机的性能监控,网络设备性能监控,数据库性能监控,FTP等通用协议监控,多种告警方式,详细的报表图表绘制),自带监控模板。
2 支持自动发现网络设备和服务器(可以通过配置自动发现规则来实现)。
3 支持自动发现(low discover ) key 实现动态监控项的批量监控(需要写脚本)。
4 支持分布式,能集中展示,管理分布式的监控点。
5 扩展性强,server 提供通用借口(API功能),可以自己开发完善各类监控。
6 编写插件容易,可以自定义监控项,报警级别的设置。
7 数据收集可用和性能检测,自定义收集数据频率,自定义检测。
8 支持snmp(包括trapping and polling ) ,IPMI, JMX, SSH ,TLENET。
9 有灵活的触发器,可以定制非常灵活的问题阀值。
10 发送通知,可定制的告警升级,收件人,媒体类型。
11 通知可以使用宏变量有用的变量。
12 自动操作包括远程命令。
13 实时的绘图功能,监控项实时的数据绘制在图形上面。
14 WEB监控能力,可以模拟鼠标点击一个网站,并检测返回值和响应时间。
15 API功能,可以方便的和其他系统结合,包括手机客户端的使用。

优点: server端对设备的性能要求低。
不足:所有的数据都存在数据库里,产生的数据量大,瓶颈主要在数据库。

我们使用compute中的其中一台服务器作为zabbix-server,占用的资源控制在比较小的范围,安装zabbix的server端以及zabbix-mysql数据库,同时,安装完成后,我们将对zabbix进行优化,定期删除历史数据,确保监控系统数据库可以永续使用,详细方法内容后续将详细描述。zabbix现在的版本是3.4,为了稳定,我们使用3.0版本。操作系统我们使用centos7.3 。下面介绍安装方法。

1.1.1.2. 安装zabbix-server

有四种方法获得Zabbix:² 从分发包安装² 下载最新的源代码档案并自行编译² 从容器中安装² 下载虚拟设备我们这里使用从分发包安装。1.1.1.2.1. [b]安装存储库配置包[/b]安装repository配置包。该软件包包含yum(软件包管理器)配置文件。# rpm -ivh http://repo.zabbix.com/zabbix/3.0/rhel/7/x86_64/zabbix-release-3.0-1.el7.noarch.rpm1.1.1.2.2. [b]安装软件包及mysql 数据库(mairadb)[/b]以下是Zabbix服务器和带有MySQL数据库的Web前端安装示例:# yum install zabbix-server-mysql zabbix-web-mysql安装mariadb数据库:#yum install mariadb-server -y在centos7软件源上现在默认的mariadb-server的版本是:5.5.56启动mariadb数据库:#systemctl start mariadb设置开机启动:#systemctl enable mariadb1.1.1.2.3. [b]创建初始数据库[/b] 通过以下命令在MySQL上创建Zabbix数据库和用户,其中<root_password>请用实际的root密码(例如shell> mysql -uroot -p12345)和<password>替换为zabbix用户在数据库上的新密码(包括撇号:)…identified by '67890';:shell> mysql -uroot -p<root_password>mysql> create database zabbix character set utf8 collate utf8_bin;mysql> grant all privileges on zabbix.* to zabbix@localhost identified by '<password>';mysql> quit; 然后导入初始模式和数据。确保插入正确的版本3.0.*。系统将提示您输入新创建的密码。# zcat /usr/share/doc/zabbix-server-mysql-3.0.*/create.sql.gz | mysql -uzabbix -p zabbix检查您的软件包中的版本,请使用以下命令:# rpm -q zabbix-server-mysql1.1.1.2.4. [b]Zabbix服务器的数据库配置[/b] 在zabbix_server.conf中编辑服务器主机,名称,用户和密码,如下所示,其中DBPassword是您设置的创建初始数据库的密码:# vi /etc/zabbix/zabbix_server.confDBHost=localhostDBName=zabbixDBUser=zabbixDBPassword=<password>1.1.1.2.5. [b]启动Zabbix服务器进程[/b]启动Zabbix服务器进程,并启动系统启动:# systemctl start zabbix-server# systemctl enable zabbix-server1.1.1.2.6. [b]PHP配置Zabbix前端[/b]Zabbix前端的Apache配置文件位于/etc/httpd/conf.d/zabbix.conf。一些PHP设置已经配置好了。但有必要取消注释“date.timezone”设置,并为您设置正确的时区。php_value max_execution_time 300php_value memory_limit 128Mphp_value post_max_size 16Mphp_value upload_max_filesize 2Mphp_value max_input_time 300php_value always_populate_raw_post_data -1php_value date.timezone Asia/Shanghai 1.1.1.2.7. [b]SELinux配置及防火墙设置[/b] 在强制模式下启用SELinux状态后,您需要执行以下命令以启用Zabbix前端到服务器的成功连接:# setsebool -P httpd_can_connect_zabbix on由于前端和SELinux配置完成,您需要重新启动Apache Web服务器:# systemctl start httpd注:一般情况下会关闭SELinux 。 如果开启了firewall,在iptables规则中开启80端口允许访问:iptables -I INPUT -p tcp -m tcp --dport 80 -m comment --comment "httpd listen " -j ACCEPT 1.1.1.2.8. [b]Zabbix web初始化[/b]登录web界面,在浏览器中输入:http://serverIP/zabbix其中serverIP是zabbix-server 所在的IP地址。















1.1.1.2.9. [b]修改配置文件[/b]生产系统,根据实际情况调整相关参数,修改配置文件/etc/zabbix/zabbix_server.conf# cat zabbix_server.confLogFile=/var/log/zabbix/zabbix_server.logDBHost=localhostDBName=zabbixDBUser=zabbixDBPassword=zabbix #数据库密码,根据实际情况修改DBSocket=/var/lib/mysql/mysql.sockDBPort=3306StartPollers=160StartTrappers=20StartPingers=100StartDiscoverers=20MaxHousekeeperDelete=5000CacheSize=1024MStartDBSyncers=16HistoryCacheSize=1024MTrendCacheSize=1024MHistoryTextCacheSize=512MAlertScriptsPath=/etc/zabbix/alertscriptsLogSlowQueries=1000FpingLocation=/usr/sbin/fpingValueCacheSize=512MTimeout=30 修改完成后重启服务:#systemctl restart zabbix-server

1.1.1.3. 安装代理zabbix-agent

根据不同的操作系统有不同的Agent。1.1.1.3.1. [b]Linux Agent安装配置[/b]1.1.1.3.1.1. [b]安装zabbix_agentd软件[/b]要在安装正确的存储库repository配置包后安装,请运行以下命令:# yum install zabbix-agent启动代理服务:# systemctl start zabbix-agent# systemctl enable zabbix-agent 1.1.1.3.1.2. [b]修改zabbix_agentd配置文件:[/b]cat /etc/zabbix/zabbix_agentd.confPidFile=/var/run/zabbix/zabbix_agentd.pidLogFile=/var/log/zabbix/zabbix_agentd.logLogFileSize=10EnableRemoteCommands=1LogRemoteCommands=1Server=127.0.0.1,10.192.1.21 #服务器IP,根据实际修改StartAgents=5ServerActive=10.192.1.21:10051 #服务器IP和端口,根据实际修改Hostname=DTS-2 #服务器名称,需要与web界面配置的host名称对应Include=/etc/zabbix/zabbix_agentd.conf.d/Timeout=30 在zabbix管理界面配置host1.1.1.3.1.3. [b]配置iptables允许10050端口[/b]如果zabbix-agent所在的linux主机启用了iptables防火墙,则需要在iptables中添加一条规则,允许10050端口访问,下面是配置方法:首先运行service iptables status查看在filter的什么位置插入,将下面的35替换为实际的位置编号iptables -I INPUT 35 -p tcp -m tcp --dport 10050 -m comment --comment "zabbix_agentd listen " -j ACCEPT 1.1.1.3.2. [b]Windows Agent安装配置[/b]从下载Zabbix Agent后,压缩包里面有2个目录,一个为win32,另一个是win64,每个目录下应该有3个文件,分别为:zabbix_agentd.exe zabbix_get.exe zabbix_sender.exe根据操作系统不同,将文件放在c:\zabbix目录下在c:\zabbix文件夹中zabbix_agentd.conf文件,写入如下内容:LogFile=d:\zabbix_agentd.logLogFileSize=10EnableRemoteCommands=1LogRemoteCommands=1Server=192.168.8.31 #服务器IP,根据实际修改StartAgents=5ServerActive=192.168.8.31:10051 #服务器IP和端口,根据实际修改Hostname=ws2 #服务器名称,需要与web界面配置的host名称对应UnsafeUserParameters=1 进入到目标主机的c:\zabbix目录下,执行如下命令完成客户端的安装:zabbix_agentd.exe -c c:\zabbix\zabbix_agentd.conf -i执行如下命令,启动客户端:zabbix_agentd.exe -c c:\zabbix\zabbix_agentd.conf -s在服务中启动zabbix_agentd服务。在windows防火墙入站规则开放10050端口如果是云计算虚拟机,在云计算的安全策略中增加入站规则开放10050端口在zabbix管理界面配置host

1.1.1.4. zabbix的配置使用

1.1.1.4.1. [b]登录zabbix [/b]通过本地浏览器访问 :http://serverIP/php 来开始配置和使用zabbix默认用户名为Admin ,密码是zabbix1.1.1.4.2. [b]监控流程[/b] Host Group (设备组)----->Host(设备)------->Application(监控项组)------->Items(监控项)------->Trigger(触发器)------>Action(告警动作)-------->(告警方式)------>User Group(用户组)----->User(用户)对于实际使用的时候,一般采用模板进行监控配置。可以先添加主机,然后选择对应模板。 zabbix支持4种监控类型:Agent SNMP JMX IPMI 1.1.1.4.3. [b]添加主机[/b]1.1.1.4.3.1. [b]修改为中文界面[/b]点击用户

在【User】-----> 【Language】 一栏中选择 Chinese(zh_CN) , 点击下方的 【Update】(更新)


中文界面出现:

1.1.1.4.3.2. [b]添加主机监控[/b]点击【配置】-----【主机】-----【创建主机】

出现如图界面,填写相应主机的相关信息,注意:群组可以新建,主机采用agent代理程序接口。如果是通过SNMP监控的网络设备,需要将agent代理程序接口关闭,填写SNMP接口

勾选【已启用】,点击【更新】

1.1.1.4.3.3. [b] 添加主机模板[/b]点击 【模板】----【选择】

在 【选择】这个界面中,勾选对应的监控模板,点击下方的选择按钮

这时候看到选择的模板在链接指示器中了,然后点击【添加】

在链接的模板一栏中出现了,可以选择【取消链接】取消这个模板。点击【更新】即可

1.1.1.4.3.4. [b] 监控展示[/b]在【主机】的主界面,看到了刚才添加的主机,点击【已启用】开启或关闭此项监控当【ZBX】 这一项变绿色,表示已经监控上了

如果是网络设备的监控,需要在【宏】中填写相应的团体名

相应的,如果SNMP这个变绿色了,表示该网络设备已经监控上了

1.1.1.4.3.5. [b]添加拓扑图[/b]在【监测中】----【拓扑图】----【创建拓扑图】

可以编辑 【所有者】,【名称】,【宽】【高】等相应的设置,点击下方的【更新】



如下出现了该拓扑图,点击【属性】,可以再次修改属性



点击该拓扑图的名称【XXXX】,进入界面后,点击【编辑拓扑图】

选择【添加】后,出现了一个图标

选中该图标,出现了【地图元素】,可以编辑该图标的属性【类型】选择 主机;【标签】可以填写 {HOST.NAME} 变量;【主机】,点击【选择】,可以选取相应的主机【图标】有一个下拉框,可以选择不同类型,不同大小的图标【应用】是确认的意思,【移除】可以删除该图标,【关闭】是关闭该地图元素

如果要添加连线,绘制各个设备之间的逻辑关系,选择链接中【添加】,进行相应操作

拓扑图编辑完成后,点击【更新】,起保存的作用

1.1.1.4.3.6. [b] 聚合图形[/b]点击【监控中】----【聚合图形】-----【创建聚合图形】



如下图,进行相应的属性设置,然后点击【添加】





点击刚才创建的【农信贷】,进行聚合图的编辑









点击【更改】,进行聚合图属性的编辑,然后点击【更新】,可以看到刚才编辑的拓扑图出现。

















先返回,再重新进入聚合图形,点击【XXX】,进入聚合图,选中任意一个设备,
会出现该主机快捷的操作列表,可以进行相应的快速查询。









1.1.1.4.4. [b] 查看数据和告警[/b]1.1.1.4.4.1. [b]监控信息概览[/b]
在 【监控中】----【仪表板】中查看告警信息的概览表,也可以直接点击进入聚合图形



1.1.1.4.4.2. [b]查看监控数据[/b]在【监测中】-----【最新数据】里,选择查询条件,点击【应用】,即可看到具体监控指标的数据以及数据的图形展示。



1.1.1.4.4.3. [b] 查看告警信息[/b]
在【监测中】----【问题】,选择相应的查询条件,点击【应用】可以看到具体的告警信息



1.1.1.4.5. [b]监控项[/b]除了zabbix自带的一些模板自动有相应的监控指标,有时候还需要手动创建一些监控项
以交换机的CPU监控为例,创建监控项
在【配置】----【主机】中选择一台交换机所对应的【监控项】



点击【创建监控项】



填写相应的信息:注意选择snmp开启的版本,和需要提前找到的OID号,
完成后,点击【更新】





可以查看刚才已经创建的监控项。点击过滤器中的应用集【CPU】,下方就出现了。
同样点击【已起用】可以开启及关闭该监控项。



1.1.1.4.6. [b]触发器[/b]通过触发器可以将监测到的数据按照设定的条件进行告警。
以一台交换机的内存为例,进行触发器告警
在【配置】---【主机】选取相应的路由器设备,点击【触发器】



点击【创建触发器】



填写触发器的相关条件,名称,告警等级,特别的在表达式这一项中,选择【添加】



如下图:触发告警条件的设置,完成后选择【插入】,然后回到上个界面,选择更新。



可以看到,刚才的触发器已经添加成功了
同样在【已启动】中可以选择停止或开启此触发器。



在【监测中】---【问题】 中可以看到路由器内存这一项已经出现告警



1.1.1.4.7. [b]邮件告警设置[/b]1.1.1.4.7.1. [b]开启邮箱[/b]以下在 zabbix server端进行
1. 安装sendmial
安装 yum install sendmail
启动 service sendmail start
开机自启: chkconfig sendmail on
2. 安装邮件发送工具mailx
yum install mailx
3. 设置发送邮件的 中继邮箱
打开配置文件: vi /etc/mail.rc
添加内容:
set from=xxx@163.cn
set smtp=smtp.163.com
set smtp-auth-user=xxx@163.com
set smtp-auth-password=xxxxxxx #注意此项是邮箱的客户端授权码,不是密码
set smtp-auth=login

4. 发送测试邮件
echo “zabbix” | mail -s “zabbix” xxx@qq.com

1.1.1.4.7.2. [b]编写脚本[/b]1. 脚本路径设置
mkdir -p /etc/zabbix/alertscripts/
vim /etc/zabbix/zabbix_server.conf
AlertScriptsPath=/etc/zabbix/alertscripts

2. 重启zabbix 服务
systemctl restart zabbix-server
3. 编写脚本:
vim /etc/zabbix/alertscripts/sendmail.sh
写入内容如下:
#!/bin/sh
#export.UTF-8
FILE=/tmp/mailtmp.txt
echo "$3" >$FILE
dos2unix -k $FILE
/bin/mail -s "$2" $1 < $FILE
touch /tmp/mailtmp.txt
chown zabbix.zabbix /tmp/mailtmp.tx
执行 :wq 保存退出

4. 增加可执行权限
chown zabbix.zabbix /etc/zabbix/alertscripts/sendmail.sh
chmod +x /etc/zabbix/alertscripts/sendmail.sh

5. 给日志授权:
chown zabbix.zabbix /tmp/sendmail.log6. 测试:
su - zabbix/etc/zabbix/alertscripts/sendmail.sh xxxx@qq.com “邮件标题” “邮件内容”

1.1.1.4.7.3. [b]登录zabbix 的web界面进行相应的配置[/b]
1. 进入告警方式配置界面,创建sendmail.sh告警方式
在【管理】----【用户】中,点击已有的用户 Admin



出现如下界面,选择【报警媒介】---【添加】----【编辑】



编辑的内容如下:







2. 编写报警媒介类型
在【管理】---【报警媒介类型中选择 【创建媒介类型】



内容如下:类型选择为脚本,以及三个参数的设置。



3. 设置zabbix 触发告警的动作
在 【配置】----【动作】中点击【创建动作】



编辑的内容如下:这里面可以设置邮件发送的条件,告警的标题,告警的内容







设置触发器,制造一个有告警等级为严重的事件(已设置)
然后查看动作日志





4. 邮件已送到









内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息