php调取 zabbix实时数据_快速部署zabbix

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

表-1 实验拓扑结构(网卡名称仅供参考,不能照抄)

31ffcfa65bd75da331c159d1ea0940a2.png

步骤一:部署监控服务器

1)安装LNMP环境

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

[root@zabbixserver ~]# yum -y install gcc pcre-devel  openssl-devel

[root@zabbixserver ~]# tar -xf nginx-1.12.2.tar.gz

[root@zabbixserver ~]# cd nginx-1.12.2

[root@zabbixserver nginx-1.12.2]# ./configure --with-http_ssl_module

[root@zabbixserver nginx-1.12.2]# make && make install

[root@zabbixserver ~]# yum -y  install  php  php-mysql  php-fpm

[root@zabbixserver ~]# yum -y  install  mariadb  mariadb-devel  mariadb-server

2)修改Nginx配置文件

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

[root@zabbixserver ~]# vim /usr/local/nginx/conf/nginx.conf
 … …
 http{

 … …

 fastcgi_buffers 8 16k;                  #缓存php生成的页面内容,8个16k

 fastcgi_buffer_size 32k;              #缓存php生产的头部信息,32k

 fastcgi_connect_timeout 300;         #连接PHP的超时时间,300秒

 fastcgi_send_timeout 300;             #发送请求的超时时间,300秒

 fastcgi_read_timeout 300;            #读取请求的超时时间,300秒

 location ~ .php$ {

              root           html;

              fastcgi_pass   127.0.0.1:9000;

              fastcgi_index  index.php;

               include        fastcgi.conf;

       }

 … …

3)启动服务

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

[root@zabbixserver ~]# systemctl start  mariadb        #启动服务
[root@zabbixserver ~]# systemctl start  php-fpm        #启动服务

[root@zabbixserver ~]# systemctl enable  mariadb        #设置开机自启

[root@zabbixserver ~]# systemctl enable  php-fpm        #设置开机自启

[root@zabbixserver ~]# /usr/local/nginx/sbin/nginx        #启动服务

[root@zabbixserver ~]# echo /usr/local/nginx/sbin/nginx  >> /etc/rc.local

[root@zabbixserver ~]# chmod +x /etc/rc.local

#通过rc.local设置开机自启

[root@zabbixserver ~]# firewall-cmd --set-default-zone=trusted

[root@zabbixserver ~]# setenforce 0
[root@zabbixserver ~]# sed -i '/SELINUX/s/enforcing/permissive/' /etc/selinux/config

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

1)源码安装Zabbix Server

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

[root@zabbixserver lnmp_soft]# yum -y install  net-snmp-devel 

 curl-devel autoconf libevent-devel

 #安装相关依赖包

[root@zabbixserver lnmp_soft]# tar -xf zabbix-3.4.4.tar.gz

[root@zabbixserver lnmp_soft]# cd zabbix-3.4.4/

[root@zabbixserver zabbix-3.4.4]# ./configure  --enable-server 

 --enable-proxy --enable-agent --with-mysql=/usr/bin/mysql_config 

 --with-net-snmp --with-libcurl

 # --enable-server安装部署zabbix服务器端软件

 # --enable-agent安装部署zabbix被监控端软件

 # --enable-proxy安装部署zabbix代理相关软件

 # --with-mysql指定mysql_config路径

 # --with-net-snmp允许zabbix通过snmp协议监控其他设备(如交换机、路由器等)

 # --with-libcurl安装相关curl库文件,这样zabbix就可以通过curl连接http等服务,测试被监控主机服务的状态

[root@zabbixserver zabbix-3.4.4]# make && make install

2)创建并初始化数据库

[root@zabbixserver ~]# mysql

mysql> create database zabbix character set utf8;

 #创建数据库,数据库名称为zabbix,character set utf8是支持中文字符集

mysql> grant all on zabbix.* to zabbix@'localhost' identified by 'zabbix';

#创建可以访问数据库的账户与密码,用户名是zabbix,密码是zabbix

[root@zabbixserver ~]# cd lnmp_soft/zabbix-3.4.4/database/mysql/

[root@zabbixserver mysql]# mysql -uzabbix -pzabbix zabbix < schema.sql

[root@zabbixserver mysql]# mysql -uzabbix -pzabbix zabbix < images.sql

[root@zabbixserver mysql]# mysql -uzabbix -pzabbix zabbix < data.sql

 #刚刚创建是空数据库,zabbix源码包目录下,有提前准备好的数据

 #使用mysql导入这些数据即可(注意导入顺序)

 #-u指定数据库用户名,-p指定数据库密码

 

如何测试?

[root@zabbixserver ~]# mysql -uzabbix -pzabbix -h 192.168.2.5 zabbix

#-u指定用户名,-p指定密码,-h指定服务器IP,最后的zabbix是数据库名称

#使用zabbix账户(密码为zabbix)连接192.168.2.5服务器上面的zabbix数据库

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

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

[root@zabbixserver ~]# vim /usr/local/etc/zabbix_server.conf

DBHost=localhost

 # 85行,定义哪台主机为数据库主机,localhost为本机

DBName=zabbix

#95行,设置数据库名称

DBUser=zabbix

 #111行,设置数据库账户

 DBPassword=zabbix

 #119行,设置数据库密码

 LogFile=/tmp/zabbix_server.log    

 #38行,日志的位置,排错使用,该行仅查看即可

[root@zabbixserver ~]# useradd -s /sbin/nologin zabbix

#服务不允许以root身份启动,不创建用户无法启动服务(用户不需要登录系统)

#创建zabbix用户才可以以zabbix用户的身份启动服务

#启动服务后可以通过ps aux查看进程是以什么用户的身份启动的

[root@zabbixserver ~]# zabbix_server                              #启动服务

[root@zabbixserver ~]# echo  zabbix_server >>  /etc/rc.local        #设置开机自启

[root@zabbixserver ~]# chmod +x  /etc/rc.local

[root@zabbixserver ~]# ss -ntulp |grep zabbix_server     #确认连接状态,端口10051

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服务。

[root@zabbixserver ~]# cd /usr/lib/systemd/system/

[root@zabbixserver ~]# vim zabbix_server.service

[Unit]

Description=zabbix server

After=network.target remote-fs.target nss-lookup.target

[Service]

Type=forking

PIDFile=/tmp/zabbix_server.pid

ExecStart=/usr/local/sbin/zabbix_server

ExecStop=/bin/kill $MAINPID

[Install]

WantedBy=multi-user.target

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

[root@zabbixserver ~]# vim /usr/local/etc/zabbix_agentd.conf

Server=127.0.0.1,192.168.2.5            #93行,允许哪些主机监控本机

ServerActive=127.0.0.1,192.168.2.5        #134行,允许哪些主机通过主动模式监控本机

Hostname=zabbix_server                #145行,设置本机主机名(名称可以任意)

LogFile=/tmp/zabbix_agentd.log            #设置日志文件(不需要修改)

UnsafeUserParameters=1                #280行,是否允许自定义监控传参

[root@zabbixserver ~]# zabbix_agentd    #启动监控agent

[root@zabbixserver ~]# echo zabbix_agentd  >> /etc/rc.local    #设置开机自启

[root@zabbixserver ~]# ss -ntulp |grep zabbix_agentd   #查看端口信息为10050

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管理服务。

 # vim /usr/lib/systemd/system/zabbix_agentd.service

 [Unit]

 Description=zabbix agent

 After=network.target remote-fs.target nss-lookup.target

 [Service]

 Type=forking

 PIDFile=/tmp/zabbix_agentd.pid

 ExecStart=/usr/local/sbin/zabbix_agentd

 ExecStop=/bin/kill $MAINPID

 [Install]

 WantedBy=multi-user.target

5)上线Zabbix的Web页面

[root@zabbixserver ~]# cd lnmp_soft/zabbix-3.4.4/frontends/php/

[root@zabbixserver php]# cp -r * /usr/local/nginx/html/

[root@zabbixserver php]# chown -R  apache.apache /usr/local/nginx/html/

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

火狐浏览器访问【 firefox http://192.168.2.5/index.php 】

#第一次访问,初始化PHP页面会检查计算机环境是否满足要求,如果不满足会给出修改建议

 #默认会提示PHP的配置不满足环境要求,需要修改PHP配置文件

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

[root@zabbixserver ~]# yum -y install  php-gd  php-xml

[root@zabbixserver ~]# yum -y install  php-bcmath  php-mbstring

[root@zabbixserver ~]# vim /etc/php.ini

date.timezone = Asia/Shanghai                #878行,设置时区

 max_execution_time = 300                    #384行,最大执行时间,秒

 post_max_size = 32M                        #672行,POST数据最大容量

 max_input_time = 300                        #394行,服务器接收数据的时间限制

[root@zabbixserver ~]# systemctl restart php-fpm

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

d8f54a121d536edcd70a7edf3041d845.png

4651fa8df748ac054c2812f7bca41359.png

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

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

3ddb49142289a19ede90c41dfb106618.png

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

d526e47d61a91aa474cb430082970100.png

9669c42f586566e266ef36dceb298a91.png

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

1)源码安装Zabbix agent软件

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

[root@web1 ~]# useradd -s /sbin/nologin  zabbix

[root@web1 ~]# yum -y install gcc pcre-devel autoconf

[root@web1 ~]# tar -xf zabbix-3.4.4.tar.gz

[root@web1 ~]# cd zabbix-3.4.4/

[root@web1 zabbix-3.4.4]# ./configure --enable-agent

[root@web1 zabbix-3.4.4]# make && make install

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

[root@web1 ~]# vim /usr/local/etc/zabbix_agentd.conf

 Server=127.0.0.1,192.168.2.5                #93行,谁可以监控本机(被动监控模式)

 ServerActive=127.0.0.1,192.168.2.5            #134行,谁可以监控本机(主动监控模式)

 Hostname=web1                                    #145行,被监控端自己的主机名

 EnableRemoteCommands=1    

#69行,监控异常后,是否允许服务器远程过来执行命令,如重启某个服务

 UnsafeUserParameters=1                    #280行,是否允许自定义key传参

[root@web1 ~]# zabbix_agentd                #启动agent服务

[root@web1 ~]# echo zabbix_agentd  >> /etc/rc.local

[root@web1 ~]# chmod +x  /etc/rc.local



[root@web1 ~]# firewall-cmd --set-default-zone=trusted

[root@web1 ~]# sed -i  '/SELINUX/s/enforcing/permissive/' /etc/selinux/config

[root@web1 ~]# setenforce 0
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值