Zabbix监控结合Grafana绘图
Zabbix 监控结合 Grafana 绘图
一.项目实验拓扑图(使用亿图专家绘图);
二.项目实验思路及重点内容(步骤及重难知
识点);
云冈网站制作公司哪家好,找创新互联公司!从网页设计、网站建设、微信开发、APP开发、成都响应式网站建设公司等网站项目制作,到程序开发,运营维护。创新互联公司自2013年创立以来到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选创新互联公司。
实施步骤:
步骤 说明
第一步 1.安装 zabbix server 服务端;
第二步 2.配置 zabbix 服务的 web 页面并做简单优化;
第三步 3.实现监控 server.zabbix.com 端的 OS 以及 MySQL、httpd;
第四步 4.安装及配置 agent.zabbix.com 被监控端(FTP 服务器);
第五步 5.登录 zabbix 的 web 界面,进行添加 agent 主机,验证监控效果;
第六步 6.配置监控 Win2k8dc1 主机,验证效果;
第七步 7.自定义监控项,创建项目、触发器、图形,验证监控效果;
第八步 8.实现邮件报警;
第九步 9.安装并配置 Grafana;
第十步 10.配置 Grafana 的 web 界面,呈现效果;
重点、难点:
重点一 1. Zabbix 简介
Zabbix 是一个企业级的开源分布式监控解决方案,由 C 语言编写而成的底层架
构(server 端和 agent 端),由一个国外的团队持续维护更新,软件可以自由下
载使用,运作团队靠提供收费的技术支持赢利。
官方网站:http://www.zabbix.com
Zabbix 通过 C/S 模式采集数据,通过 B/S 模式在 web 端展示和配置。
被监控端:主机通过安装 agent 方式采集数据,网络设备通过 SNMP 方式采集
数据
Server 端:通过收集 SNMP 和 agent 发送的数据,写入 MySQL 数据库,再通过
php+apache 在 web 前端展示。
- Zabbix 运行条件:
Server:
Zabbix Server 需运行在 LAMP(Linux+Apache+Mysql+PHP)环境下,对硬件
要求低
Agent:
目前已有的 agent 基本支持市面常见的 OS,包含 Linux、HPUX、Solaris、Sun、
windows 等
SNMP:
支持各类常见的网络设备 - Zabbix 功能
具备常见的商业监控软件所具备的功能(主机的性能监控、网络设备性能监控、
数据库性能监控、FTP 等通用协议监控、多种告警方式、详细的报表图表绘制)
支持自动发现网络设备和服务器,支持分布式,能集中展示、管理分布式的监控
点,扩展性强,server 提供通用接口,可以自己开发完善各类监控。
重点二 1. 优劣势
优点:
开源,无软件成本投入;
Server 对设备性能要求低(实际测试环境:虚拟机 Redhat EL AS5,2GCPU 1G
内存,监控 5 台设备,CPU 使用率基本保持在 10%以下,内存剩余 400M 以上);
支持设备多;
支持分布式集中管理;
开放式接口,扩展性强;
当监控的 item 比较多服务器队列比较大时可以采用被动状态,被监控客户端
主动从 server 端去下载需要监控的 item 然后取数据上传到 server 端。这种方式
对服务器的负载比较小。
缺点:
无厂家支持,出现问题解决比较麻烦
需在被监控主机上安装 agent,所有数据都存在数据库里,产生的数据据很大,
瓶颈主要在数据库。
重点三 1.zabbix 的监控原理:
组件说明:
1)zabbix server:负责接收 agent 发送的报告信息的核心组件,所有配置、统计
数据及操作数据都由它组织进行;
2)database storage:专用于存储所有配置信息,以及由 zabbix 收集的数据;
3)web interface:zabbix 的 GUI 接口;
4)proxy:可选组件,常用于监控节点很多的分布式环境中,代理 server 收集部
分数据转发到 server,可以减轻 server 的压力;
5)agent:部署在被监控的主机上,负责收集主机本地数据如 cpu、内存、数据
库等数据发往 server 端或 proxy 端;
监控流程:
agentd 需要安装到被监控的主机上,它负责定期收集各项数据,并发送到
zabbix server 端,zabbix server 将数据存储到数据库中,zabbix web 根据数据在前
端进行展现和绘图。这里 agentd 收集数据分为主动和被动两种模式:
主动:agent 请求 server 获取主动的监控项列表,并主动将监控项内需要检测
的数据提交给 server/proxy
被动:server 向 agent 请求获取监控项的数据,agent 返回数据。
客户端守护进程:
此进程收集客户端数据,例如 cpu 负载、内存、硬盘使用情况等。
zabbix_get
zabbix 工具,单独使用的命令,通常在 server 或者 proxy 端执行获取远程客户
端信息的命令。通常用户排错。例如在 server 端获取不到客户端的内存数据,我
们可以使用 zabbix_get 获取客户端的内容的方式来做故障排查。
zabbix_sender
zabbix 工具,用于发送数据给 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 教程系列。
zabbix_java_gateway
zabbix2.0 之后引入的一个功能。顾名思义:Java 网关,类似 agentd,但是只
用于 Java 方面。需要特别注意的是,它只能主动去获取数据,而不能被动获取
数据。它的数据最终会给到 server 或者 proxy。
重点四 扩展:zabbix 的监控架构
在实际监控架构中,zabbix 根据网络环境、监控规模等 分了三种架构:
server-client 、master-node-client、server-proxy-client 三种 。
1、server-client 架构
也是 zabbix 的最简单的架构,监控机和被监控机之间不经过任何代理 ,直接
由 zabbix server 和 zabbix agentd 之间进行数据交互。适用于网络比较简单,设备
比较少的监控环境 。
2、server-proxy-client 架构
其中 proxy 是 server、client 之间沟通的一个桥梁,proxy 本身没有前端,而且
其本身并不存放数据,只是将 agentd 发来的数据暂时存放,而后再提交给
server 。该架构经常是和 master-node-client 架构做比较的架构 ,一般适用于跨
机房、跨网络的中型网络架构的监控。
3、master-node-client 架构
该架构是 zabbix 最复杂的监控架构,适用于跨网络、跨机房、设备较多的大型
环境 。每个 node 同时也是一个 server 端,node 下面可以接 proxy,也可以直接
接 client 。node 有自已的配置文件和数据库,其要做的是将配置信息和监控数
据向 master 同步,master 的故障或损坏对 node 其下架构的完整性。
重点五 Grafana 简介:
Grafana 是一个可视化面板(Dashboard),有着非常漂亮的图表和布局展示,
功能齐全的度量仪表盘和图形编辑器,支持 Graphite、zabbix、InfluxDB、
Prometheus 和 OpenTSDB 作为数据源。以 InfluxDB(由 go 语言编写,是一个开
源,分布式,时间序列,事件,可度量和无外部依赖的数据库)作为底层数据库;
Grafana 主要特性:灵活丰富的图形化选项;可以混合多种风格;支持白天和
夜间模式;多个数据源。
三.项目实验步骤(操作截图或者操作命令)
1.安装 zabbix server 服务端;
[root@server ~]# ip a ##配置网络,确保可以上网
1: lo: mtu 65536 qdisc noqueue state UNKNOWN qlen 1
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft forever
2: eth0: mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 00:0c:29:4f:c9:00 brd ff:ff:ff:ff:ff:ff
inet 192.168.100.101/24 brd 192.168.100.255 scope global eth0
valid_lft forever preferred_lft forever
[root@server ~]# vi /etc/hosts
192.168.100.101 server.zabbix.com
192.168.100.152 agent.zabbix.com
192.168.100.153 win2k8dc1
:wq
[root@server ~]# wget -O /etc/yum.repos.d/CentOS-Base.repo
http://mirrors.aliyun.com/repo/Centos-7.repo
[root@server ~]# yum -y install net-snmp net-snmp-devel libxml2 libxml2-devel libcurl-devel
libevent libevent libevent-devel curl curl-devel mysql-devel snmp perl-DBI php-xml php-bcmath
php-mbstring php-ldap php-xmlrpc httpd php php-mysql php-common php-gd php-odbc
php-pear gcc* net-snmp libssh3 libssh3-devel mariadb-server mariadb mariadb-devel ntpdate
##安装 lamp 和依赖包,使用默认的 centos 7 中的默认 yun 源
[root@server ~]# ntpdate ntp1.aliyun.com
10 Sep 09:08:09 ntpdate[1225]: adjust time server 120.25.115.20 offset -0.000095 sec
[root@server ~]# echo "ntpdate ntp1.aliyun.com" >>/etc/rc.local
[root@server ~]# chmod +x /etc/rc.local
[root@server ~]# systemctl start mariadb
[root@server ~]# systemctl enable mariadb
Created symlink from /etc/systemd/system/multi-user.target.wants/mariadb.service to
/usr/lib/systemd/system/mariadb.service.
[root@server ~]# systemctl start httpd
[root@server ~]# systemctl enable httpd
Created symlink from /etc/systemd/system/multi-user.target.wants/httpd.service to
/usr/lib/systemd/system/httpd.service.
[root@server ~]# mysqladmin -u root password
123123
123123
[root@server ~]# wget -O zabbix-3.4.2.tar.gz
http://sourceforge.net/projects/zabbix/files/ZABBIX%20Latest%20Stable/3.4.2/zabbix-3.4.2.tar.gz
/download ##下载软件包,上传也可
[root@server ~]# tar zxvf zabbix-3.4.2.tar.gz
[root@server ~]# cd zabbix-3.4.2
[root@server ~]# ./configure --prefix=/usr/local/zabbix --enable-server --enable-agent
--with-mysql --enable-ipv6 --with-net-snmp --with-libcurl --with-libxml2
[root@server ~]# make &&make install
[root@server ~]# mysql -uroot -p123123 ##登陆数据库创建保存监控模板的数据库,并
导入数据模板,以及授权 zabbix 用户连接数据库;
create database if not exists zabbix default character set utf8 collate utf8_general_ci;
use zabbix;
source /root/zabbix-3.4.2/database/mysql/schema.sql;
source /root/zabbix-3.4.2/database/mysql/images.sql;
source /root/zabbix-3.4.2/database/mysql/data.sql;
grant all on zabbix.* to zabbix@'192.168.100.101' identified by 'zabbix';
flush privileges;
show grants for zabbix@'192.168.100.101';
exit
[root@server ~]# groupadd zabbix
[root@server ~]# useradd -r -g zabbix zabbix
[root@server ~]# mkdir /usr/local/zabbix/logs
[root@server ~]# chown zabbix:zabbix /usr/local/zabbix/ -R
[root@server ~]# vi /usr/local/zabbix/etc/zabbix_server.conf
:%g/^#/d
:%g/^$/d
LogFile=/usr/local/zabbix/logs/zabbix_server.log
PidFile=/tmp/zabbix_server.pid
DBHost=192.168.100.101
DBName=zabbix
DBUser=zabbix
DBPassword=zabbix
DBSocket=/var/lib/mysql/mysql.sock
Include=/usr/local/zabbix/etc/zabbix_server.conf.d/*.conf
:wq
[root@server ~]# vi /usr/local/zabbix/etc/zabbix_agentd.conf
:%g/^#/d
:%g/^$/d
PidFile=/tmp/zabbix_agentd.pid
Server=127.0.0.1,192.168.100.101
ServerActive=192.168.100.101
Hostname=server.zabbix.com
LogFile=/usr/local/zabbix/logs/zabbix_agentd.log
Include=/usr/local/zabbix/etc/zabbix_agentd.conf.d/*.conf
:wq
解释:
PidFile=/tmp/zabbix_agentd.pid ##运行的 PID 文件
Server=127.0.0.1,192.168.100.101 ##输入 zabbix_server 主机的 ip 地址
ServerActive=192.168.100.101 ##输入 agent 主机采集到数据发送到的 server 端
Hostname=server.zabbix.com ##输入本机的主机名
LogFile=/usr/local/zabbix/logs/zabbix_agentd.log ##指定日志文件
Include=/usr/local/zabbix/etc/zabbix_agentd.conf.d/*.conf ##开启附加配置文件目录
[root@server ~]# /usr/local/zabbix/sbin/zabbix_server
[root@server ~]# netstat -utpln |grep 10051
tcp 0 0 0.0.0.0:10051 0.0.0.0:* LISTEN
29079/zabbix_server
[root@server ~]# /usr/local/zabbix/sbin/zabbix_agentd
[root@server ~]# netstat -utpln |grep 10050
tcp 0 0 0.0.0.0:10050 0.0.0.0:* LISTEN
29148/zabbix_agentd
[root@server ~]# mv /root/zabbix-3.4.2/frontends/php/ /var/www/html/zabbix
[root@server ~]# chown -R apache:apache /var/www/html/zabbix/
[root@server ~]# vi /etc/php.ini
878 date.timezone = Asia/Shanghai
384 max_execution_time = 300
394 max_input_time = 300
672 post_max_size = 32M
405 memory_limit = 128M
854 extension=bcmath.so
:wq
解释:
878 date.timezone = Asia/Shanghai ##时区
384 max_execution_time = 300 ##单位秒,通过 POST、GET 以及 PUT 方式接
收数据时间进行限制
394 max_input_time = 300 ##php 程序上传文件解析数据时的时间限制
672 post_max_size = 32M ##POST 方式请求数据所允许的最大大小
405 memory_limit = 128M ##设置 php 程序的内存限制
854 extension=bcmath.so ##加载 zabbix 程序需要加载的扩展模块 bcmath.so
[root@server ~]# systemctl restart httpd
2.配置 zabbix 服务的 web 页面并做简单优化;
访问安装 http://192.168.100.101/zabbix/,默认用户名 admin 密码 zabbix
安装完成,设置显示字体为中文;
解决 zabbix 显示图像下边文字乱码情况:
上传字符集文件到此目录下;
3.实现监控 server.zabbix.com 端的 OS 以及 mysql、httpd;
4
勾选以下三个监控模板,点击选择按钮;
在上个界面会显示此主机的监控项,此主机的图形,可以自行跟据监控项进行创建图形;
选择监控项,点击选择;
查看监控主机的图形;
但是意外出现了,关于 Mysql 数据库的所有监控项没有图形,如图所示;
经过查看,问题如下图,监控 Mysql 服务器的键值不使用;
解决方案如下;
设置监控失效的键值,打开 zabbix_server 服务器,同时在此也是被监控端;
[root@server ~]# vi /usr/local/zabbix/etc/zabbix_agentd.conf
PidFile=/tmp/zabbix_agentd.pid
Server=127.0.0.1,192.168.100.101
ServerActive=192.168.100.101
Hostname=server.zabbix.com
LogFile=/usr/local/zabbix/logs/zabbix_agentd.log
Include=/usr/local/zabbix/etc/zabbix_agentd.conf.d/*.conf
UnsafeUserParameters=1
UserParameter=mysql.version,mysql -V
UserParameter=mysql.status[*],/usr/local/zabbix/etc/chk_mysql.sh $1
UserParameter=mysql.ping,mysqladmin -uroot -p123123 -P3306 -h292.168.100.101 ping | grep
-c alive
:wq
内容解释:
Server=192.168.100.151,127.0.0.1 //指定 zabbix 服务器的地址
ServerActive=192.168.100.101 //指定 agent 采集到数据之后发送给 server 端
Hostname=server.zabbix.com //指定 agent 端的主机名、server 端必须需要解析,注意:
在 web 界面添加被监控主机时,必须写此主机名;
UnsafeUserParameters=1 //允许所有字符的参数传递给用户定义的参数。
UserParameter=mysql.version,mysql -V //定义键值 mysql.version,以及键值的值 mysql -V
UserParameter=mysql.status[*],/usr/local/zabbix/etc/chk_mysql.sh $1 // 定 义 键 值
mysql.status[*]
UserParameter=mysql.ping,mysqladmin -uroot -p123123 -P3306 -h292.168.100.101 ping | grep
-c alive ///定义键值 mysql.ping,指定 chk_mysql.sh 脚本,使用此脚本检查 mysql 的运
行状态,使用 mysqladmin 命令指定 agent 端的数据库连接用户密码 ip 地址,注意保证
mysqladmin 命令的链接;
[root@server ~]# vi /usr/local/zabbix/etc/chk_mysql.sh ##编写检查 mysql 状态的脚本,
在脚本中指定 agent 端的 mysql 的 ip 地址,连接的用户名密码等
#!/bin/bash
#-------------------------------------------------------------------------------
#FileName: check_mysql.sh
#Revision: 1.0
#Date: 2015/06/09
#Author: DengYun
#Email: dengyun@ttlsa.com
#Website: www.ttlsa.com
#Description:
#Notes: ~
#-------------------------------------------------------------------------------
#Copyright: 2015 (c) DengYun
#License: GPL
#用户名
MYSQL_USER='root'
#密码
MYSQL_PWD='123123'
#主机地址/IP
MYSQL_HOST='192.168.100.101'
#端口
MYSQL_PORT='3306'
#数据连接
MYSQL_CONN="/usr/bin/mysqladmin -u${MYSQL_USER} -p${MYSQL_PWD} -h${MYSQL_HOST}
-P${MYSQL_PORT}"
#参数是否正确
if [ $# -ne "1" ];then
echo "arg error!"
fi
#获取数据
case $1 in
Uptime)
result=`${MYSQL_CONN} status|cut -f2 -d":"|cut -f1 -d"T"`
echo $result
;;
Com_update)
result=`${MYSQL_CONN} extended-status |grep -w "Com_update"|cut -d"|" -f3`
echo $result
;;
Slow_queries)
result=`${MYSQL_CONN} status |cut -f5 -d":"|cut -f1 -d"O"`
echo $result
;;
Com_select)
result=`${MYSQL_CONN} extended-status |grep -w "Com_select"|cut -d"|" -f3`
echo $result
;;
Com_rollback)
result=`${MYSQL_CONN} extended-status |grep -w "Com_rollback"|cut -d"|" -f3`
echo $result
;;
Questions)
result=`${MYSQL_CONN} status|cut -f4 -d":"|cut -f1 -d"S"`
echo $result
;;
Com_insert)
result=`${MYSQL_CONN} extended-status |grep -w "Com_insert"|cut -d"|" -f3`
echo $result
;;
Com_delete)
result=`${MYSQL_CONN} extended-status |grep -w "Com_delete"|cut -d"|" -f3`
echo $result
;;
Com_commit)
result=`${MYSQL_CONN} extended-status |grep -w "Com_commit"|cut -d"|" -f3`
echo $result
;;
Bytes_sent)
result=`${MYSQL_CONN} extended-status |grep -w "Bytes_sent" |cut -d"|" -f3`
echo $result
;;
Bytes_received)
result=`${MYSQL_CONN} extended-status |grep -w "Bytes_received" |cut -d"|" -f3`
echo $result
;;
Com_begin)
result=`${MYSQL_CONN} extended-status |grep -w "Com_begin"|cut -d"|" -f3`
echo $result
;;
*)
echo
"Usage:$0(Uptime|Com_update|Slow_queries|Com_select|Com_rollback|Questions|Com_inser
t|Com_delete|Com_commit|Bytes_sent|Bytes_received|Com_begin)"
;;
esac
:wq
[root@server ~]# chmod 777 /usr/local/zabbix/etc/chk_mysql.sh
[root@server ~]# mysql -uroot -p123123
grant all on *.* to 'root'@'192.168.100.101' identified by '123123';
flush privileges;
show grants for root@'192.168.100.101';
exit
[root@server ~]# ln -s /usr/local/zabbix/bin/* /usr/local/bin/ //为 zabbix 的命令做软链
接,检测 mysql 状态时会使用 zabbix_get 命令
[root@server ~]# yum -y install psmisc
[root@server ~]# killall -9 zabbix_server
[root@server ~]# killall -9 zabbix_agentd
[root@server ~]# /usr/local/zabbix/sbin/zabbix_server
[root@server ~]# /usr/local/zabbix/sbin/zabbix_agentd
[root@server ~]# netstat -utpln |grep 100
tcp 0 0 0.0.0.0:10050 0.0.0.0:* LISTEN
29800/zabbix_agentd
tcp 0 0 0.0.0.0:10051 0.0.0.0:* LISTEN
29733/zabbix_server
[root@server ~]# vi /etc/my.cnf ##禁止反向解析
[mysqld]
skip-name-resolve
[root@server ~]# systemctl restart mariadb
[root@server ~]# zabbix_get -s 192.168.100.101 -k mysql.ping ##在此可以通过 zabbix_get
命令进行获取服务器监控项的具体键值,mysql.ping 是在 zabbix_agentd.conf 配置文件中的键
值名称,通过此名称可以查看键值,通常能够获取到键值,获取监控数据就是没问题的;
1
[root@server ~]# zabbix_get -s 192.168.100.101 -k mysql.status[Com_update]
143
[root@server ~]# zabbix_get -s 192.168.100.101 -k mysql.version
mysql Ver 15.1 Distrib 5.5.56-MariaDB, for Linux (x86_64) using readline 5.1
再次打开 zabbix 的 web 界面,验证 mysql 服务器的监控界面;
按照如上方法将 server.linuxfan.cn 的 httpd 服务的状态添加到 zabbix 的图形中;
4.安装及配置 zabbix_agentd 代理端(FTP 服务器);
首先安装 zabbix_agentd 端的测试服务(ftp)并且确保网络通信;
[root@agent ~]# ip a
1: lo: mtu 16436 qdisc noqueue state UNKNOWN
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
2: eth0: mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 00:0c:29:a0:76:46 brd ff:ff:ff:ff:ff:ff
inet 192.168.100.152/24 brd 192.168.100.255 scope global eth0
inet6 fe80::20c:29ff:fea0:7646/64 scope link
valid_lft forever preferred_lft forever
[root@agent ~]# vi /etc/sysconfig/network
NETWORKING=yes
HOSTNAME=agent.zabbix.com
:wq
[root@agent ~]# vi /etc/hosts
192.168.100.101 server.zabbix.com
192.168.100.152 agent.zabbix.com
192.168.100.153 win2k8dc1
:wq
[root@agent ~]# reboot
[root@agent ~]# ping server.zabbix.com -c 4
[root@agent ~]# yum -y install vsftpd
[root@agent ~]# /etc/init.d/vsftpd start
其次开始配置 agent.zabbix.com 被监控端主机的 zabbix 的 agent 代理端;
[root@agent ~]# wget -O /etc/yum.repos.d/CentOS-Base.repo
http://mirrors.aliyun.com/repo/Centos-7.repo
[root@agent ~]# yum -y install libxml2-devel libcurl-devel pcre-devel ntpdate
[root@agent ~]# ntpdate ntp1.aliyun.com
[root@agent ~]# wget -O zabbix-3.4.2.tar.gz
http://sourceforge.net/projects/zabbix/files/ZABBIX%20Latest%20Stable/3.4.2/zabbix-3.4.2.tar.gz
/download
[root@agent ~]# tar zxvf zabbix-3.4.2.tar.gz
[root@agent ~]# cd zabbix-3.4.2
[root@agent zabbix-3.4.2]# ./configure --prefix=/usr/local/zabbix --enable-agent --enable-ipv6
--with-net-snmp --with-libcurl --with-libxml2
[root@agent zabbix-3.4.2]# make &&make install
[root@agent zabbix-3.4.2]# cp misc/init.d/tru64/zabbix_agentd /etc/init.d/
[root@agent zabbix-3.4.2]# vi /etc/init.d/zabbix_agentd
24 DAEMON=/usr/local/zabbix/sbin/zabbix_agentd
:wq
[root@agent zabbix-3.4.2]# chmod +x /etc/init.d/zabbix_agentd
[root@agent zabbix-3.4.2]# cd
[root@agent ~]# groupadd zabbix
[root@agent ~]# useradd -r -g zabbix zabbix
[root@agent ~]# chown -R zabbix:zabbix /usr/local/zabbix/
[root@agent ~]# vi /usr/local/zabbix/etc/zabbix_agentd.conf
:%g/^$/d
:%g/^#/d
LogFile=/tmp/zabbix_agentd.log
Server=192.168.100.101
ServerActive=192.168.100.101
Hostname=agent.zabbix.com
:wq
[root@agent ~]# /etc/init.d/zabbix_agentd start
Zabbix agent started.
[root@agent ~]# netstat -utpln |grep zabbix
tcp 0 0 0.0.0.0:10050 0.0.0.0:* LISTEN
12481/zabbix_agentd
tcp 0 0 :::10050 :::* LISTEN
12481/zabbix_agentd
5.登录 zabbix 的 web 界面,进行添加 agent 主机,验证监
控效果;
添加 agent.zabbix.com 主机完成,默认的图形之后五个,无 ftp 服务图形,接下来手动添加
ftp 服务图形显示;
6.配置监控 Win2k8dc1 主机,验证效果;
首先配置 windows2008 主机的网络;
其次用宿主机访问 zabbix 官网下载监控 windows2008 的插件;
下载完成,将下载后的插件复制到测试主机 win2k8dc1 中,进行配置;
C:\zabbix\bin\win64\zabbix_agentd.exe -c C:\zabbix\conf\zabbix_agentd.win.conf -i ##安装
C:\zabbix\bin\win64\zabbix_agentd.exe -c C:\zabbix\conf\zabbix_agentd.win.conf -s ##启动
C:\zabbix\bin\win64\zabbix_agentd.exe -c C:\zabbix\conf\zabbix_agentd.win.conf -d ##删除
windows 主机配置完成,下边在 web 界面,添加主机 win2k8dc1;
添加完成,默认图形为 2 个,可以手动添加,在此不做过多说明,验证当前图形如下;
7.自定义监控项,创建项目、触发器、图形,验证监控效果;
以上关联的 Template OS Linux 模板基本涵盖了所有系统层面的监控,包括了我们最关注的
几项:ping、load、cpu 使用率、memory、disk、网卡流量等等,当然有些触发器的阀值可
能需要根据服务器的自身情况进行修改。
下面添加自定义服务器内存使用检测项,在此配置一个监控项为:内存使用 70M 进行警告
提醒:
1.修改客户端 zabbix_agentd.conf 配置文件,最后一行添加:
UserParameter=memory_userd,free -m|grep Mem|awk '{print $3}'
语法:UserParameter=key,shell command
监控 key 值:memory_userd,key 值可以随意编写,但是一会需要在 web 页面创建监控项时
指定 key 值;
Shell 命令或脚本:free -m|grep Mem|awk '{print $3}'
注:在 zabbix_server 端可以使用 zabbix_get -s agent 端 ip 地址 -p 10050 -k key 名
通过此命令可以查看 agent 端 key 的监控值;
具体实现方式如下,更改 agent.zabbix.com 主机的配置文件来自定义监控项;
[root@agent ~]# vi /usr/local/zabbix/etc/zabbix_agentd.conf
UserParameter=memory_userd,free -m|grep Mem|awk '{print $3}'
:wq
[root@agent ~]# /etc/init.d/zabbix_agentd restart
使用 server.agent.com 主机查看其监控项键值;
[root@server ~]# zabbix_get -s 192.168.100.152 -k memory_userd
338
使用 web 界面添加此监控项;
监控项添加完成后,创建触发器(根据条件进行触发某个告警操作);
触发器创建完成后,创建监控显示的图形;
打开首页,很明显的提示;
8.实现邮件报警;
首先配置 server.zabbix.com 端的邮件;
[root@server ~]# yum -y install postfix mailx dos2unix
[root@server ~]# mailx -V
[root@server ~]# vi /etc/mail.rc //在此文件末尾添加,指定接收邮件邮箱地址,指定邮
箱服务器地址,指定接收邮件邮箱地址的授权码,并非 163 邮箱的密码,而是授权码,登陆
163 网易邮箱地址后,--设置--开启 smtp 和 pop3--点击客户端生成授权码--使用此授权码进
行指定到此配置文件;
set from=li__wenhu@163.com smtp=smtp.163.com
set smtp-auth-user=li__wenhu@163.com smtp-auth-password=...
set smtp-auth=login
:wq
[root@server ~]# echo "测试内容" |mail -s "测试标题" li__wenhu@163.com // 测 试 邮 件
接收情况
[root@server ~]# vi /usr/local/zabbix/etc/zabbix_server.conf //打开 server 端主配置文
件的脚本存放位置
AlertScriptsPath=/usr/local/zabbix/share/zabbix/alertscripts
:wq
[root@server ~]# vi /usr/local/zabbix/share/zabbix/alertscripts/2.sh //编写报警邮件
脚本,调整 mail 命令语法位置,使用 dos2unix 命令转换字符,避免收到邮件不显示正常邮
件内容而出现 ATT00001.bin 的错误;
#!/bin/bash
#export.UTF-8
bt=$2
sjr=$1
FILE=/tmp/mailtmp.txt
echo "$3" >$FILE
/usr/bin/dos2unix -k $FILE
/bin/mail -s "$bt" "$sjr" <$FILE
:wq
[root@server ~]# chmod 777 /usr/local/zabbix/share/zabbix/alertscripts/2.sh
[root@server ~]# chown zabbix:zabbix /usr/local/zabbix/share/zabbix/alertscripts/2.sh
[root@server ~]# touch /tmp/mailtmp.txt
[root@server ~]# chmod 777 /tmp/mailtmp.txt
[root@server ~]# chown zabbix:zabbix /tmp/mailtmp.txt //注意文件以及报警脚本
的归属以及权限,注:脚本文件和存放邮件消息文件归属必须是 zabbix;
[root@server ~]# /usr/local/zabbix/share/zabbix/alertscripts/2.sh li__wenhu@163.com "测试标
题 2" "测试内容 2" //测试脚本邮件接收情况
dos2unix: converting file /tmp/mailtmp.txt to Unix format ...
配置 zabbix web 网站进行监控项的邮件报警,每一张图片后附带解释和注意事项,大体
步骤分为 监控--创建报警媒介类型--更新用户使用的报警媒介类型--创建动作(根据触发器
触发)--验证;
创建报警媒介类型:
输入创建的报警媒介类型的名称,指定类型为脚本的方式,并且输入 zabbix_server 端
/usr/local/zabbix/share/zabbix/alertscripts 目录下的脚本名称,确保脚本的归属是 zabbix,
并且脚本的权限是 777,下边设置脚本参数,也就是发送邮件的语法:脚本 收件人 标题 内
容,必须严格按照此标准填写;
创建报警媒介类型成功后,进行确认;
配置 zabbix 中的用户所使用的报警媒介类型以及接收邮件的邮箱;
选择报警媒介类型为刚刚创建的类型,并且输入接收邮件的地址,指定报警时间和报警级
别;
创建动作,也就是发送邮件的动作;
输入动作名,动作名最好为英文,可以选择触发这个动作的条件(可以选择触发器=触发器
的名称或者选择触发器似触发器名称),作为条件,如若如图不选择触发器的条件,那么任
何消息都会提示到邮箱;
添加报警动作,一旦此触发器添加触发,添加报警邮件的标题和内容,默认操作步骤持续
时间(修改持续时间为 60 秒 (一分钟发送一次邮件)),添加操作(添加接收邮件的用户);
默认接收人内容:故障{TRIGGER.STATUS},服务器:{HOSTNAME1}发生: {TRIGGER.NAME}故障!
默认信息内容:
告警主机:{HOSTNAME1}
告警时间:{EVENT.DATE} {EVENT.TIME}
告警等级:{TRIGGER.SEVERITY}
告警信息: {TRIGGER.NAME}
告警项目:{TRIGGER.KEY1}
问题详情:{ITEM.NAME}:{ITEM.VALUE}
当前状态:{TRIGGER.STATUS}:{ITEM.VALUE1}
事件 ID:{EVENT.ID}
添加操作(添加接收邮件的用户),步骤(指定邮件发送的次数),仅送到(选择创建的媒
介类型);
添加恢复操作(指故障恢复之后发送邮件的动作),具体步骤和添加操作相同;
确认动作创建的完成;
开始测试邮件报警
测试一:首先关闭 agent.zabbix.com 主机的 ftp 服务,测试邮件报警情况;
[root@agent ~]# /etc/init.d/vsftpd stop
关闭 vsftpd: [确定]
测试二:关闭 win2k8 主机,测试邮件报警情况;
9.安装并配置 Grafana;
[root@server ~]# wget
https://s3-us-west-2.amazonaws.com/grafana-releases/release/grafana-4.6.1-1.x86_64.rpm
[root@server ~]# yum -y localinstall grafana-4.6.1-1.x86_64.rpm
[root@server ~]# grafana-cli plugins install alexanderzobnin-zabbix-app ##安装 zabbix 插
件
[root@server ~]# mkdir -p /opt/grafana/data/plugins/
[root@server ~]# cp -r /var/lib/grafana/plugins/alexanderzobnin-zabbix-app/
/opt/grafana/data/plugins/
[root@server ~]# ls /opt/grafana/data/plugins/
alexanderzobnin-zabbix-app
[root@server ~]# chmod 777 /opt/grafana/data/plugins/ -R
[root@server ~]# systemctl start grafana-server
[root@server ~]# netstat -utpln |grep gra
Proto Recv-Q Send-Q Local Address Foreign Address State
PID/Program name
tcp 0 0 0.0.0.0:3000 0.0.0.0:* LISTEN
57103/grafana-serve
访问测试 http://192.168.100.101:3000,默认用户名 admin,密码 admin,在此是谷歌浏览器
翻译过后的界面,大家可以自行下载谷歌浏览器,下载翻译插件,在此不做过多介绍;
安装 grafana;
10.配置 Grafana 的 web 界面,呈现效果;
启用插件;
添加数据源;
创建仪表盘;
创建仪表盘时指定显示的图形;
输入图形名称;
选择数据源和图中需要显示的主机和主机的监控项;
创建完成,保存此仪表盘,输入仪表盘的名称;
验证创建的仪表盘;
在现有的 dashboard 中添加图形;
验证最终的仪表盘显示图形;
四.项目实验总结(遇到的错误及解决方案,
难点、重点解说,扩展学习)
1.错误及解决方案:
错误一:监控 Mysql 数据库时,没有图形;
错误及解决方案:P/13-18
错误二:配置报警邮件时,邮箱收到的邮件为 ATT00001.bin 的内容;
错误及解决方案:P/38
邮箱收到邮件出现 ATT00001.bin 的内容:
原因:zabbix 无法将内容转义成中英文,需要借助 dos2unix工具进行转换
新闻标题:Zabbix监控结合Grafana绘图
链接分享:http://pcwzsj.com/article/piijgd.html