千家信息网

Zabbix 监控结合 Grafana 绘图

发表于:2025-01-27 作者:千家信息网编辑
千家信息网最后更新 2025年01月27日,Zabbix 监控结合 Grafana 绘图一.项目实验拓扑图(使用亿图专家绘图);二.项目实验思路及重点内容(步骤及重难知识点);实施步骤:步骤 说明第一步 1.安装 zabbix server 服
千家信息网最后更新 2025年01月27日Zabbix 监控结合 Grafana 绘图

Zabbix 监控结合 Grafana 绘图

一.项目实验拓扑图(使用亿图专家绘图);

二.项目实验思路及重点内容(步骤及重难知
识点);

实施步骤:
步骤 说明
第一步 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 前端展示。

  1. Zabbix 运行条件:
    Server:
    Zabbix Server 需运行在 LAMP(Linux+Apache+Mysql+PHP)环境下,对硬件
    要求低
    Agent:
    目前已有的 agent 基本支持市面常见的 OS,包含 Linux、HPUX、Solaris、Sun、
    windows 等
    SNMP:
    支持各类常见的网络设备
  2. 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 forever2: 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-odbcphp-pear gcc* net-snmp libssh3 libssh3-devel mariadb-server mariadb mariadb-devel ntpdate##安装 lamp 和依赖包,使用默认的 centos 7 中的默认 yun 源[root@server ~]# ntpdate ntp1.aliyun.com10 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 mariadbCreated 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 httpdCreated symlink from /etc/systemd/system/multi-user.target.wants/httpd.service to /usr/lib/systemd/system/httpd.service.[root@server ~]# mysqladmin -u root password123123123123[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 10051tcp 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 10050tcp 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.confPidFile=/tmp/zabbix_agentd.pidServer=127.0.0.1,192.168.100.101ServerActive=192.168.100.101Hostname=server.zabbix.comLogFile=/usr/local/zabbix/logs/zabbix_agentd.logInclude=/usr/local/zabbix/etc/zabbix_agentd.conf.d/*.confUnsafeUserParameters=1UserParameter=mysql.version,mysql -VUserParameter=mysql.status[*],/usr/local/zabbix/etc/chk_mysql.sh $1UserParameter=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 -VUserParameter=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'#主机地址/IPMYSQL_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_insert|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 100tcp 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.versionmysql 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 a1: 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 forever2: 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 startZabbix agent started.[root@agent ~]# netstat -utpln |grep zabbixtcp 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.comset 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-8bt=$2sjr=$1FILE=/tmp/mailtmp.txtecho "$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 graProto 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工具进行转换

0