案例:部署Zabbix监控平台

1 问题

本案例要求部署一台Zabbix监控服务器,一台被监控主机,为进一步执行具体的监控任务做准备:

  1. 安装LNMP环境
  2. 源码安装Zabbix
  3. 安装监控端主机,修改基本配置
  4. 初始化Zabbix监控Web页面
  5. 修改PHP配置文件,满足Zabbix需求
  6. 安装被监控端主机,修改基本配置

2 方案

使用1台RHEL7虚拟机,安装部署LNMP环境、Zabbix及相关的依赖包,配置数据库并对Zabbix监控平台进行初始化操作。使用2台被监控端,源码安装Zabbix Agent。完成Zabbix实验需要我们搭建一个实验环境,拓扑结构如表-1所示。

表-1 实验拓扑结构

3 步骤

实现此案例需要按照如下步骤进行。

步骤一:部署监控服务器

1)安装LNMP环境

Zabbix监控管理控制台需要通过Web页面展示出来,并且还需要使用MySQL来存储数据,因此需要先为Zabbix准备基础LNMP环境。

  1. [root@zabbixserver ~]# yum -y install gcc pcre-devel openssl-devel
  2. [root@zabbixserver ~]# tar -xf nginx-1.12.tar.gz
  3. [root@zabbixserver ~]# cd nginx-1.12
  4. [root@zabbixserver nginx-1.12]# ./configure --with-http_ssl_module
  5. [root@zabbixserver nginx-1.12]# make && make install
  6. [root@zabbixserver ~]# yum -y install php php-mysql \
  7. > mariadb mariadb-devel mariadb-server
  8. [root@zabbixserver ~]# yum -y install php-fpm-5.4.16-42.el7.x86_64.rpm
  9. //注意,php-fpm这个软件包在lnmp_soft/目录下

2)修改Nginx配置文件

配置Nginx支持PHP动态网站,因为有大量PHP脚本需要执行,因此还需要开启Nginx的各种fastcgi缓存,加速PHP脚本的执行速度。

  1. [root@zabbixserver ~]# vim /usr/local/nginx/conf/nginx.conf
  2. … …
  3. http{
  4. … …
  5. fastcgi_buffers 8 16k;                 //缓存php生成的页面内容,8个16k
  6. fastcgi_buffer_size 32k;                 //缓存php生产的头部信息
  7. fastcgi_connect_timeout 300;             //连接PHP的超时时间
  8. fastcgi_send_timeout 300;                 //发送请求的超时时间
  9. fastcgi_read_timeout 300;                     //读取请求的超时时间
  10. location ~ \.php$ {
  11. root html;
  12. fastcgi_pass 127.0.0.1:9000;
  13. fastcgi_index index.php;
  14. include fastcgi.conf;
  15. }
  16. … …

3)启动服务

启动Nginx、PHP-FPM、MariaDB服务,关闭SELinux与防火墙。

  1. [root@zabbixserver ~]# systemctl start mariadb
  2. [root@zabbixserver ~]# systemctl start php-fpm
  3. [root@zabbixserver ~]# ln -s /usr/local/nginx/sbin/nginx /sbin/nginx
  4. [root@zabbixserver ~]# nginx
  5. [root@zabbixserver ~]# firewall-cmd --set-default-zone=trusted
  6. [root@zabbixserver ~]# setenforce 0

4)客户端测试LNMP环境

服务器创建PHP测试页面,浏览器访问页面测试网页连通性。

  1. [root@zabbixserver ~]# cat /usr/local/nginx/html/test.php
  2. <?php
  3. $i=33;
  4. echo $i;
  5. ?>
  6. [root@zabbixserver ~]# curl http://192.168.2.5/test.php

步骤二:部署监控服务器Zabbix Server

1)源码安装Zabbix Server

多数源码包都是需要依赖包的,zabbix也一样,源码编译前需要先安装相关依赖包。

  1. [root@zabbixserver lnmp_soft]# yum -y install net-snmp-devel \
  2. > curl-devel
  3. //安装相关依赖包
  4. [root@zabbixserver lnmp_soft]# yum -y install \
  5. > libevent-devel-2.0.21-4.el7.x86_64.rpm
  6. //注意libevent-devel这个软件包在lnmp_soft目录下有提供
  7. [root@zabbixserver lnmp_soft]# tar -xf zabbix-3.4.4.tar.gz
  8. [root@zabbixserver lnmp_soft]# cd zabbix-3.4.4/
  9. [root@zabbixserver zabbix-3.4.4]# ./configure --enable-server \
  10. > --enable-proxy --enable-agent --with-mysql=/usr/bin/mysql_config \
  11. > --with-net-snmp --with-libcurl
  12. // --enable-server安装部署zabbix服务器端软件
  13. // --enable-agent安装部署zabbix被监控端软件
  14. // --enable-proxy安装部署zabbix代理相关软件
  15. // --with-mysql配置mysql_config路径
  16. // --with-net-snmp允许zabbix通过snmp协议监控其他设备
  17. // --with-libcurl安装相关curl库文件,这样zabbix就可以通过curl连接http等服务,测试被监控主机服务的状态
  18. [root@zabbixserver zabbix-3.4.4]# make && make install

2)初始化Zabbix

创建数据库,上线Zabbix的Web页面

  1. [root@zabbixserver ~]# mysql
  2. mysql> create database zabbix character set utf8;
  3. //创建数据库,支持中文字符集
  4. mysql> grant all on zabbix.* to zabbix@'localhost' identified by 'zabbix';
  5. //创建可以访问数据库的账户与密码
  6. [root@zabbixserver ~]# cd lnmp_soft/zabbix-3.4.4/database/mysql/
  7. [root@zabbixserver mysql]# mysql -uzabbix -pzabbix zabbix < schema.sql
  8. [root@zabbixserver mysql]# mysql -uzabbix -pzabbix zabbix < images.sql
  9. [root@zabbixserver mysql]# mysql -uzabbix -pzabbix zabbix < data.sql
  10. //刚刚创建是空数据库,zabbix源码包目录下,有提前准备好的数据
  11. //使用mysql导入这些数据即可(注意导入顺序)

上线Zabbix的Web页面

  1. [root@zabbixserver ~]# cd lnmp_soft/zabbix-3.4.4/frontends/php/
  2. [root@zabbixserver php]# cp -r * /usr/local/nginx/html/
  3. [root@zabbixserver php]# chmod -R 777 /usr/local/nginx/html/*

修改Zabbix_server配置文件,设置数据库相关参数,启动Zabbix_server服务

  1. [root@zabbixserver ~]# vim /usr/local/etc/zabbix_server.conf
  2. DBHost=localhost
  3. //数据库主机,默认该行被注释
  4. DBName=zabbix
  5. //设置数据库名称
  6. DBUser=zabbix
  7. //设置数据库账户
  8. DBPassword=zabbix
  9. //设置数据库密码,默认该行被注释
  10. LogFile=/tmp/zabbix_server.log
  11. //设置日志,仅查看以下即可
  12. [root@zabbixserver ~]# useradd -s /sbin/nologin Zabbix
  13. //不创建用户无法启动服务
  14. [root@zabbixserver ~]# zabbix_server                 //启动服务
  15. [root@zabbixserver ~]# ss -ntulp |grep zabbix_server //确认连接状态,端口10051
  16. tcp LISTEN 0 128 *:10051 *:* users:(("zabbix_server",pid=23275,fd=4),("zabbix_server",pid=23274,fd=4)

提示:如果是因为配置文件不对,导致服务无法启动时,不要重复执行zabbix_server,

一定要先使用killall zabbix_server关闭服务后,再重新启动一次。

修改Zabbix_agent配置文件,启动Zabbix_agent服务

  1. [root@zabbixserver ~]# vim /usr/local/etc/zabbix_agentd.conf
  2. Server=127.0.0.1,192.168.2.5                    //允许哪些主机监控本机
  3. ServerActive=127.0.0.1,192.168.2.5                //允许哪些主机通过主动模式监控本机
  4. Hostname=zabbix_server                        //设置本机主机名
  5. LogFile=/tmp/zabbix_server.log                    //设置日志文件
  6. UnsafeUserParameters=1                        //是否允许自定义key
  7. [root@zabbixserver ~]# zabbix_agentd            //启动监控agent
  8. [root@zabbixserver ~]# ss -ntulp |grep zabbix_agentd //查看端口信息为10050
  9. tcp LISTEN 0 128 *:10050 *:* users:(("zabbix_agentd",pid=23505,fd=4),("zabbix_agentd",pid=23504,fd=4)

提示:如果是因为配置文件不对,导致服务无法启动时,不要重复执行zabbix_agentd,

一定要先使用killall zabbix_agentd关闭服务后,再重新启动一次。

浏览器访问Zabbix_server服务器的Web页面

  1. [root@zabbixserver ~]# firefix http://192.168.2.5/index.php
  2. //第一次访问,初始化PHP页面会检查计算机环境是否满足要求,如果不满足会给出修改建议
  3. //默认会提示PHP的配置不满足环境要求,需要修改PHP配置文件

根据错误提示,修改PHP配置文件,满足Zabbix_server的Web环境要求

php-bcmath和php-mbstring都在lnmp_soft目录下有提供软件包。

  1. [root@zabbixserver ~]# yum -y install php-gd php-xml
  2. [root@zabbixserver ~]# yum install php-bcmath-5.4.16-42.el7.x86_64.rpm
  3. [root@zabbixserver ~]# yum install php-mbstring-5.4.16-42.el7.x86_64.rpm
  4. [root@zabbixserver ~]# vim /etc/php.ini
  5. date.timezone = Asia/Shanghai                //设置时区
  6. max_execution_time = 300                    //最大执行时间,秒
  7. post_max_size = 32M                        //POST数据最大容量
  8. max_input_time = 300                        //服务器接收数据的时间限制
  9. memory_limit = 128M                        //内存容量限制
  10. [root@zabbixserver ~]# systemctl restart php-fpm

修改完PHP配置文件后,再次使用浏览器访问服务器,则会提示如图-1和图-2所示的提示信息。

图-1

图-2

在初始化数据库页面,填写数据库相关参数,如图-3所示。

图-3

在登陆页面,使用用户(admin)和密码(zabbix)登陆,登陆后设置语言环境为中文,如图-4和图-5所示。

图-4

图-5

步骤三:部署被监控主机Zabbix Agent

1)源码安装Zabbix agent软件

在2.100和2.200做相同操作(以zabbixclient_web1为例)。

  1. [root@zabbixclient_web1 ~]# useradd -s /sbin/nologin zabbix
  2. [root@zabbixclient_web1 ~]# yum -y install gcc pcre-devel
  3. [root@zabbixclient_web1 ~]# tar -xf zabbix-3.4.4.tar.gz
  4. [root@zabbixclient_web1 ~]# cd zabbix-3.4.4/
  5. [root@zabbixclient_web1 zabbix-3.4.4]# ./configure --enable-agent
  6. [root@zabbixclient_web1 zabbix-3.4.4]# make && make install

拷贝启动脚本(非必须操作,可选做),有启动脚本可以方便管理服务,启动与关闭服务。启动脚本位于zabbix源码目录下。

  1. [root@zabbixclient_web1 zabbix-3.4.4]# cd misc/init.d/fedora/core
  2. [root@zabbixclient_web1 zabbix-3.4.4]# cp zabbix_agentd /etc/init.d/
  3. [root@zabbixclient_web1 zabbix-3.4.4]# /etc/init.d/Zabbix_agentd start
  4. [root@zabbixclient_web1 zabbix-3.4.4]# /etc/init.d/Zabbix_agentd stop
  5. [root@zabbixclient_web1 zabbix-3.4.4]# /etc/init.d/Zabbix_agentd status
  6. [root@zabbixclient_web1 zabbix-3.4.4]# /etc/init.d/Zabbix_agentd restart

3)修改agent配置文件,启动Agent

  1. [root@zabbixclient_web1 ~]# vim /usr/local/etc/zabbix_agentd.conf
  2. Server=127.0.0.1,192.168.2.5                //谁可以监控本机(被动监控模式)
  3. ServerActive=127.0.0.1,192.168.2.5            //谁可以监控本机(主动监控模式)
  4. Hostname=zabbix_client_zabbixclient_web1                //被监控端自己的主机名
  5. EnableRemoteCommands=1
  6. //监控异常后,是否允许服务器远程过来执行命令,如重启某个服务
  7. UnsafeUserParameters=1                    //是否允许自定义key监控
  8. [root@zabbixclient_web1 ~]# zabbix_agentd                //启动agent服务

案例:配置及使用Zabbix监控系统

1 问题

沿用练习一,使用Zabbix监控平台监控Linux服务器,实现以下目标:

  1. 监控CPU
  2. 监控内存
  3. 监控进程
  4. 监控网络流量
  5. 监控硬盘

2 方案

通过Zabbix监控平台,添加被监控zabbixclient_web1主机(192.168.2.100)并链接监控模板即可,Zabbix默认模板就可以监控CPU、内存、进程、网络、磁盘等项目。

3 步骤

实现此案例需要按照如下步骤进行。

步骤一:添加监控主机

主机是Zabbix监控的基础,Zabbix所有监控都是基于Host主机。

使用火狐浏览器登录http://192.168.2.5,通过Configuration(配置)-->Hosts(主机)-->Create Host(创建主机)添加被监控Linux主机,如图-7所示。

图-7

添加被监控主机时,需要根据提示输入被监控Linux主机的主机名称、主机组、IP地址等参数,具体参考图-8所示。

图-8

步骤二:为被监控主机添加监控模板

Zabbix通过监控模板来对监控对象实施具体的监控功能,根据模板来定义需要监控哪些数据,对于Linux服务器的监控,Zabbix已经内置了相关的模板(Template OS Linux),选择模板并链接到主机即可,如图-9所示。

图-9

步骤三:查看监控数据

查看监控数据,登录Zabbix Web控制台,点击Monitoring(监控中)—> Latest data(最新数据),正过滤器中填写过滤条件,根据监控组和监控主机选择需要查看哪些监控数据,如图-10所示。

图-10

找到需要监控的数据后,可以点击后面的Graph查看监控图形,如图-11所示。

案例:自定义Zabbix监控项目

4.1 问题

沿用练习二,使用Zabbix实现自定义监控,实现以下目标:监控Linux服务器系统账户的数量。

4.2 方案

需要使用Zabbix自定义key的方式实现自定义监控,参考如下操作步骤:

  1. 创建自定义key
  2. 创建监控项目
  3. 创建监控图形
  4. 将监控模板关联到主机

4.3 步骤

实现此案例需要按照如下步骤进行。

步骤一:被监控主机创建自定义key(在192.168.2.100操作)

1)创建自定义key

自定义key语法格式为:UserParameter=自定义key名称,命令。

自定义的key文件一般存储在/usr/local/etc/zabbix_agentd.conf.d/目录,这里还需要修改zabbix_agentd.conf文件,允许自定义监控key,来读取该目录下的所有文件 。

  1. [root@zabbixclient_web1 ~]# vim /etc/zabbix/zabbix_agentd.conf
  2. Include=/usr/local/etc/zabbix_agentd.conf.d/                //加载配置文件目录
  3. [root@zabbixclient_web1 ~]# cd /usr/local/etc/zabbix_agentd.conf.d/
  4. [root@zabbixclient_web1 zabbix_agentd.conf.d]# vim count.line.passwd
  5. UserParameter=count.line.passwd,wc -l /etc/passwd | awk ' {print $1} '
  6. ////自定义key语法格式:
  7. //UserParameter=自定义key名称,命令

2)测试自定义key是否正常工作

  1. [root@zabbixclient_web1 ~]# killall zabbix_agentd
  2. [root@zabbixclient_web1 ~]# zabbix_agentd                                //重启agent服务
  3. [root@zabbixclient_web1 ~]# zabbix_get -s 127.0.0.1 -k count.line.passwd
  4. 21

注意:如zabbix_get命令执行错误,提示Check access restrictions in Zabbix agent configuration,则需要检查agent配置文件是否正确:

  1. [root@zabbixclient_web1 ~]# vim /usr/local/etc/zabbix_agentd.conf
  2. Server=127.0.0.1,192.168.2.5
  3. ServerActive=127.0.0.1,192.168.2.5

步骤二:创建监控模板

模板、应用集与监控项目的关系图,参考图-12所示

图-12

1)添加监控模板

登录Zabbix Web监控控制台,通过Configuration(配置)-->Template(模板)-->Create template(创建模板),填写模板名称,新建模板群组,如图-13所示。

图-13

创建模板后,默认模板中没有任何应用、项目、触发器、图形等,如图-14所示。

图-14

2)创建应用

创建完成模板后,默认模板中没有任何应用、项目、触发器、图形等资源。这里需要点击模板后面的Application(应用集)链接打开创建应用的页面,如图-15所示。

图-15

点击Application(应用集)后,会刷新出图-16所示页面,在该页面中点击Create application(创建应用集)按钮。

图-16

设置应用名称如图-17所示。

图-17

3)创建监控项目item(监控项)

与创建应用一样,在模板中还需要创建监控项目,如图-18所示,并在刷新出的新页面中选择Create items(创建监控项)创建项目,如图-19所示。

图-18

图-19

接下来,还需要给项目设置名称及对应的自定义key,如图-20所示。

图-20

4)创建图形

为了后期可以通过图形的方式展示监控数据,还需要在模板中创建图形,设置方法与前面的步骤一致,在监控模板后面点击Graph(图形)即可创建图形,设置监控图形基于什么监控数据,如图-21所示。

图-21

5)将模板链接到被监控主机

将完整的监控模板制作完成后,就可以将模板链接到主机实现监控功能了。首先找到被监控主机Configuration(配置)-->Hosts(主机),如图-22所示。

图-22

点击需要的被监控主机链接,打开监控主机设置页面,在Template(模板)页面中选择需要链接到该主机的模板,在此选择刚刚创建的模板count_line.passwd添加即可,如图-23所示。

图-23

6)查看监控数据图形

点击Monitoring(监控中)-->Craphs(图形),根据需要选择条件,查看监控图形,如图-24和图-25所示。

图-25

部署zabbix监控平台(源码安装)的更多相关文章

  1. Security基础(六):部署Zabbix监控平台、配置及使用Zabbix监控系统、自定义Zabbix监控项目、实现Zabbix报警功能

    一.部署Zabbix监控平台 目标: 本案例要求部署一台Zabbix监控服务器,一台被监控主机,为进一步执行具体的监控任务做准备: 在监控服务器上安装LAMP环境    修改PHP配置文件,满足Zab ...

  2. 一、安装zabbix监控(源码编方式)

    首先介绍一下zabbix的运行原理和运行条件. Zabbix监控原理 Zabbix 通过C/S 模式采集数据,通过B/S模式在web 端展示和配置.  被监控端:主机通过安装agent 方式采集数据, ...

  3. zabbix 3.2源码安装

    环境: centos7.2 nginx 1.10.3 mysql 5.5.38 php 5.5.38 一.zabbix介绍 1.Zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企 ...

  4. [原创] zabbix学习之旅一:源码安装

    zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案.zabbix能监视各种网络参数,保证服务器系统的安全运营:并提供灵活的通知机制以让系统管理员快速定位/解决存 ...

  5. Zabbix监控平台

                                                                     Zabbix监控平台 案例1:常用系统监控命令 案例2:部署Zabbi ...

  6. Zabbix监控系统部署:源码安装

    1. 概述1.1 基础环境2. 部署过程2.1 创建用户组2.2 下载源码解压编译安装2.2.1 下载源码解压2.2.2 YUM安装依赖环境2.2.3 编译安装最新版curl2.2.4 更新GNU构建 ...

  7. zabbix server端与agent端源码安装 自定义监控项

    ZabbixServer的安装(只有源码装zabbix才能装支持java) 搭建自定义yum仓库并安装支持包 yum -y install createrepo #下载依赖关系命令 createrep ...

  8. Zabbix源码安装部署

    zabbix源码部署安装 参考文档:https://www.zabbix.com/documentation/4.0/manual/installation/install ​ https://www ...

  9. 以源码安装的lamp环境为依托,源码安装zabbix监控系统

    1.源码安装lamp环境 1)安装httpd, 以源码httpd-2.4.33为基础,解压后,执行./configure --prefix=/usr/local/ --sysconfdir=/etc/ ...

随机推荐

  1. httprunnermanager环境搭建 -----转

    转发自  https://www.cnblogs.com/tiechui2015/p/10017801.html  感谢大神 1,开源代码下载 这里的git下载地址是:https://github.c ...

  2. Linux卸载Django

    cd /usr/lib/python2.7/dist-packages sudo rm -rf django sudo rm Django-1.8.7.egg-info 基本命令如此,具体文件因版本有 ...

  3. GC详解及Minor GC和Full GC触发条件

    GC,即就是Java垃圾回收机制.目前主流的JVM(HotSpot)采用的是分代收集算法.与C++不同的是,Java采用的是类似于树形结构的可达性分析法来判断对象是否还存在引用.即:从gcroot开始 ...

  4. .NET Core 3全新来袭!DevExpress Winforms v19.2支持High DPI

    DevExpress Winforms Controls 内置140多个UI控件和库,完美构建流畅.美观且易于使用的应用程序.无论是Office风格的界面,还是分析处理大批量的业务数据,DevExpr ...

  5. Vue 组件的通信

    vue不得不了解的就是组件间的数据通信(暂且不谈vuex插件). 通信方式根据组件之间的关系有不同之处. 组件关系有下面三种:父-->子.子-->父.非父子 1.父-->子 父向子传 ...

  6. 慕课网SSM仿大众点评

    目录: 配置部分: 1 配置报错不支持diamond运算符 运行部分: 1 登录的账号密码 2 运行项目是报错session超时 配置部分 1 配置报错不支持diamond运算符 原报错信息如下:id ...

  7. Educational Codeforces Round 72 (Rated for Div. 2) B题

    Problem Description: You are fighting with Zmei Gorynich — a ferocious monster from Slavic myths, a ...

  8. 002_linux驱动之_register_chrdev注册字符设备

    (一)解析:register_chrdev函数和unregister_chrdev函数 (二)register_chrdev函数原型 int register_chrdev(unsigned int ...

  9. 配置文件的属性ENC加密

    转载:https://www.cnblogs.com/zqyx/p/9687136.html 在micro service体系中,有了config server,我们可以把配置存放在git.svn.数 ...

  10. ActiveMQ C#实例

    重点参考:NMS Documentation 一.ActiveMQ Queue 在ActiveMQ中Queue是一种点对点的消息分发方式,生产者在队列中添加一条消息,然后消费者消费一条消息,这条消息保 ...