其他分享
首页 > 其他分享> > 部署Zabbix监控平台

部署Zabbix监控平台

作者:互联网

1. 部署Zabbix监控平台

步骤一:部署监控服务器

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.2.tar.gz
3 [root@zabbixserver ~]# cd nginx-1.12.2
4 [root@zabbixserver nginx-1.12.2]# ./configure --with-http_ssl_module
5 [root@zabbixserver nginx-1.12.2]# make && make install
6 [root@zabbixserver ~]# yum -y  install  php  php-mysql  php-fpm
7 [root@zabbixserver ~]# yum -y  install  mariadb  mariadb-devel  mariadb-server

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生产的头部信息,32k
 7     fastcgi_connect_timeout 300;         #连接PHP的超时时间,300秒
 8     fastcgi_send_timeout 300;             #发送请求的超时时间,300秒
 9     fastcgi_read_timeout 300;            #读取请求的超时时间,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         }

3)启动服务

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

 1 [root@zabbixserver ~]# systemctl start  mariadb        #启动服务
 2 [root@zabbixserver ~]# systemctl start  php-fpm        #启动服务
 3 [root@zabbixserver ~]# systemctl enable  mariadb        #设置开机自启
 4 [root@zabbixserver ~]# systemctl enable  php-fpm        #设置开机自启
 5 [root@zabbixserver ~]# /usr/local/nginx/sbin/nginx        #启动服务
 6 [root@zabbixserver ~]# echo /usr/local/nginx/sbin/nginx  >> /etc/rc.local
 7 [root@zabbixserver ~]# chmod +x /etc/rc.local
 8 #通过rc.local设置开机自启
 9 [root@zabbixserver ~]# firewall-cmd --set-default-zone=trusted
10 [root@zabbixserver ~]# setenforce 0
11 [root@zabbixserver ~]# sed -i '/SELINUX/s/enforcing/permissive/' /etc/selinux/config

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

1)源码安装Zabbix Server

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

 1 [root@zabbixserver lnmp_soft]# yum -y install  net-snmp-devel \
 2 curl-devel autoconf libevent-devel
 3 #安装相关依赖包
 4 [root@zabbixserver lnmp_soft]# tar -xf zabbix-3.4.4.tar.gz
 5 [root@zabbixserver lnmp_soft]# cd zabbix-3.4.4/
 6 [root@zabbixserver zabbix-3.4.4]# ./configure  --enable-server \
 7  --enable-proxy --enable-agent --with-mysql=/usr/bin/mysql_config \
 8  --with-net-snmp --with-libcurl
 9 # --enable-server安装部署zabbix服务器端软件
10 # --enable-agent安装部署zabbix被监控端软件
11 # --enable-proxy安装部署zabbix代理相关软件
12 # --with-mysql指定mysql_config路径
13 # --with-net-snmp允许zabbix通过snmp协议监控其他设备(如交换机、路由器等)
14 # --with-libcurl安装相关curl库文件,这样zabbix就可以通过curl连接http等服务,测试被监控主机服务的状态
15 [root@zabbixserver zabbix-3.4.4]# make && make install

2)创建并初始化数据库

 1 [root@zabbixserver ~]# mysql
 2 mysql> create database zabbix character set utf8;
 3 #创建数据库,数据库名称为zabbix,character set utf8是支持中文字符集
 4 mysql> grant all on zabbix.* to zabbix@'localhost' identified by 'zabbix';
 5 #创建可以访问数据库的账户与密码,用户名是zabbix,密码是zabbix
 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导入这些数据即可(注意导入顺序)
12 #-u指定数据库用户名,-p指定数据库密码
13 如何测试?
14 [root@zabbixserver ~]# mysql -uzabbix -pzabbix -h localhost zabbix
15 #-u指定用户名,-p指定密码,-h指定服务器IP,最后的zabbix是数据库名称
16 #使用zabbix账户(密码为zabbix)连接localhost服务器上面的zabbix数据库

3)修改zabbix_server配置并启动监控服务

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

 1 [root@zabbixserver ~]# vim /usr/local/etc/zabbix_server.conf
 2 DBHost=localhost
 3 # 85行,定义哪台主机为数据库主机,localhost为本机
 4 DBName=zabbix
 5 #95行,设置数据库名称
 6 DBUser=zabbix
 7 #111行,设置数据库账户
 8 DBPassword=zabbix
 9 #119行,设置数据库密码
10 LogFile=/tmp/zabbix_server.log    
11 #38行,日志的位置,排错使用,该行仅查看即可
12 [root@zabbixserver ~]# useradd -s /sbin/nologin zabbix
13 #服务不允许以root身份启动,不创建用户无法启动服务(用户不需要登录系统)
14 #创建zabbix用户才可以以zabbix用户的身份启动服务
15 #启动服务后可以通过ps aux查看进程是以什么用户的身份启动的
16 [root@zabbixserver ~]# zabbix_server      #启动服务(不推荐这么启动服务,推荐使用systemctl启动服务,下面有service文件模板)
17 [root@zabbixserver ~]# echo  zabbix_server >>  /etc/rc.local        #设置开机自启
18  [root@zabbixserver ~]# chmod +x  /etc/rc.local
19 [root@zabbixserver ~]# ss -ntulp |grep zabbix_server     #确认连接状态,端口10051
20 tcp LISTEN 0 128 *:10051 *:* users:(("zabbix_server",pid=23275,fd=4),("zabbix_server",pid=23274,fd=4)

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

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

安装psmisc软件包,才有killall命令。

(非必须操作):也可以通过创建service文件管理zabbix服务。

 1 [root@zabbixserver ~]# cd /usr/lib/systemd/system/
 2 [root@zabbixserver ~]# vim zabbix_server.service 
 3 [Unit]
 4 Description=zabbix server
 5 After=network.target remote-fs.target nss-lookup.target
 6 [Service]
 7 Type=forking
 8 PIDFile=/tmp/zabbix_server.pid
 9 ExecStart=/usr/local/sbin/zabbix_server
10 ExecStop=/bin/kill $MAINPID
11 [Install]
12 WantedBy=multi-user.target

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

 1 [root@zabbixserver ~]# vim /usr/local/etc/zabbix_agentd.conf
 2 Server=127.0.0.1,192.168.2.5            #93行,允许哪些主机监控本机
 3 ServerActive=127.0.0.1,192.168.2.5        #134行,允许哪些主机通过主动模式监控本机
 4 Hostname=zabbix_server                #145行,设置本机主机名(名称可以任意)
 5 LogFile=/tmp/zabbix_agentd.log            #设置日志文件(不需要修改)
 6 UnsafeUserParameters=1                #280行,是否允许自定义监控传参
 7 [root@zabbixserver ~]# zabbix_agentd    #启动监控agent(不推荐这么启动服务,推荐使用systemctl启动服务,下面有service文件模板)
 8 [root@zabbixserver ~]# echo zabbix_agentd  >> /etc/rc.local    #设置开机自启
 9 [root@zabbixserver ~]# ss -ntulp |grep zabbix_agentd   #查看端口信息为10050
10 tcp    LISTEN     0      128       *:10050                 *:*                   users:(("zabbix_agentd",pid=23505,fd=4),("zabbix_agentd",pid=23504,fd=4)

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

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

安装psmisc软件包,才有killall命令。

(非必须操作)编写zabbix_agentd的service文件,通过systemd管理服务。

 1 # vim /usr/lib/systemd/system/zabbix_agentd.service
 2 [Unit]
 3 Description=zabbix agent
 4 After=network.target remote-fs.target nss-lookup.target
 5 [Service]
 6 Type=forking
 7 PIDFile=/tmp/zabbix_agentd.pid
 8 ExecStart=/usr/local/sbin/zabbix_agentd
 9 ExecStop=/bin/kill $MAINPID
10 [Install]
11 WantedBy=multi-user.target

5)上线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]# chown -R  apache.apache /usr/local/nginx/html/

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

1 火狐浏览器访问【 firefox http://192.168.2.5/index.php 】
2 #第一次访问,初始化PHP页面会检查计算机环境是否满足要求,如果不满足会给出修改建议
3 #默认会提示PHP的配置不满足环境要求,需要修改PHP配置文件

根据错误提示,安装依赖、修改PHP配置文件,满足Zabbix_server的环境要求。

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

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

 

注意:这里有一个PHP LDAP是warning状态是没有问题的!

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

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

 

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

1)源码安装Zabbix agent软件

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

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

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

 1 [root@web1 ~]# vim /usr/local/etc/zabbix_agentd.conf
 2 Server=127.0.0.1,192.168.2.5                #93行,谁可以监控本机(被动监控模式)
 3 ServerActive=127.0.0.1,192.168.2.5            #134行,谁可以监控本机(主动监控模式)
 4 Hostname=web1                        #145行,被监控端自己的主机名
 5 EnableRemoteCommands=1    
 6 #69行,监控异常后,是否允许服务器远程过来执行命令,如重启某个服务
 7 UnsafeUserParameters=1                    #280行,是否允许自定义key传参
 8 [root@web1 ~]# zabbix_agentd                #启动agent服务(不推荐这么启动服务,推荐使用systemctl启动服务,上面有service文件模板)
 9 [root@web1 ~]# echo zabbix_agentd  >> /etc/rc.local
10 [root@web1 ~]# chmod +x  /etc/rc.local
11 [root@web1 ~]# firewall-cmd --set-default-zone=trusted
12 [root@web1 ~]# sed -i  '/SELINUX/s/enforcing/permissive/' /etc/selinux/config
13 [root@web1 ~]# setenforce 0

2. 配置及使用Zabbix监控系统

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

步骤一:添加监控主机

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

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

 添加被监控主机时,需要根据提示输入被监控Linux主机的主机名称(最好与电脑的主机名一致,但也允许不一致)、主机组、IP地址等参数,具体参考图

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

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

步骤三:查看监控数据

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

 找到需要监控的数据后,可以点击后面的Graph(图形)查看监控图形,如图

3. 自定义Zabbix监控项目

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

1)创建自定义key

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

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

1 [root@web1 ~]# vim /usr/local/etc/zabbix_agentd.conf
2 Include=/usr/local/etc/zabbix_agentd.conf.d/             #264行,加载配置文件目录
3 [root@web1 ~]# cd /usr/local/etc/zabbix_agentd.conf.d/
4 [root@web1 zabbix_agentd.conf.d]# vim count.line.passwd
5 UserParameter=count.line.passwd,sed -n '$=' /etc/passwd
6 #自定义key语法格式:
7 #UserParameter=自定义key名称,命令

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

1 [root@web1 ~]# killall  zabbix_agentd
2 [root@web1 ~]# zabbix_agentd                                #重启agent服务
3 [root@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@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

步骤二:创建监控模板

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

1)添加监控模板

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

 创建模板后,默认模板中没有任何应用集、监控项、触发器、图形等,如图

2)创建应用集

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

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

 设置应用集名称,名称可以任意,如图

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

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

 

 

接下来,还需要给项目设置名称(名称可以任意)及对应的自定义key(必须与前面自定义的监控key名称一致),如图

 

4)创建图形

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

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

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

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

6)查看监控数据图形

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

 

 

#思维导图#

 

标签:部署,zabbixserver,zabbix,Zabbix,监控,root,模板
来源: https://www.cnblogs.com/Zhangtao-linux/p/14577116.html