liuyuehua 发表于 2018-1-1 22:55:50

zabbix实现mysql数据库的监控(一)

  zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。它能监视各种网络参数,保证服务器系统的安全运营;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。
  zabbix由2部分构成,zabbix server与可选组件zabbix agent。zabbix server可以通过SNMP,zabbix agent,ping,端口监视等方法提供对远程服务器/网络状态的监视,数据收集等功能。zabbix agent需要安装在被监视的目标服务器上,它主要完成对硬件信息或与操作系统有关的内存,CPU等信息收集。zabbix server可以单独监视远程服务器的服务状态;同时也可以与zabbix agent配合,可以轮询zabbix agent主动接收监视数据(agent方式),同时还可被动接收zabbix agent发送的数据。
  一、搭建Zabbix监控环境
  要想搭建一个Zabbix的工作环境,需要从服务器入手。与服务器通信,管理员需要使用一个Zabbix前端界面,与Zabbix服务器和数据库进行通信。三个关键(界面、服务器和数据库)可以安装在同一台服务器上,但是如果你拥有一个更大更复杂的环境,将它们安装在不同的主机上也是一个选项。Zabbix服务器能够直接监控到同一网络中的设备,如果其他网络的设备也需要被监控,那还需要一台Zabbix代理服务器。
  【部署环境说明】:

  1、环境准备(在zabbix server上)
  (1)安装LAMP环境:由于zabbix界面是php写的,所以这里显示需要安装LAMP开发环境,mysql5.6已经安装,直接用yum安装apache简单省事。
  

# yum install httpd php -y  

  (2)开启相关服务,主要httpd,mysqld
  

# chkconfig httpd on  
# /etc/init.d/httpd start
  

  (3)安装zabbix server需要的依赖包
  

#yum installgcc net-snmp-develmysql-devel curl-devel perl-DBI php-gd php-mysql php-bcmath php-mbstring php-xml-y  

  (4)创建zabbix运行账户
  

# groupadd zabbix  
# useradd -r -g zabbix -s /sbin/nologin zabbix
  

  2、安装zabbix server(192.168.245.133)
  

# tar zxvf zabbix-2.4.6.tar.gz  
#cd zabbix-2.4.6
  
# ./configure --prefix=/usr/local/zabbix --enable-server --enable-agent --enable-proxy --with-mysql --with-net-snmp --with-libcurl
  
# make install
  

  3、安装fping
  用于同时ping多台主机。下载地址:http://www.fping.org/dist/
  

# tar zxvf fping-3.13.tar.gz  
# cd fping-3.13
  
# ./configure && make install
  
# chown root.zabbix /usr/local/sbin/fping
  
# chmod 4710 /usr/local/sbin/fping
  

  4、配置zabbix
  zabbix server配置与启动大概需要以下几个步骤:
  (1)创建zabbix数据库和mysql用户
  

mysql>create database zabbix character set utf8;  
Query OK, 1 row affected (0.22 sec)
  mysql>grant all privileges on zabbix.* to zabbix@'%'>  Query OK, 0 rows affected (0.02 sec)
  mysql> flush privileges;
  Query OK, 0 rows affected (0.00 sec)
  

  (2)导入zabbix数据库初始化数据
  

# cd /home/software/zabbix-2.4.6/database/mysql/  
# /data/mysql/bin/mysql -uzabbix -pzabbix zabbix <schema.sql
  
# /data/mysql/bin/mysql -uzabbix -pzabbix zabbix <images.sql
  
# /data/mysql/bin/mysql -uzabbix -pzabbix zabbix <data.sql
  

  注意:以上导入的顺序不能乱。
  (3)编辑zabbix配置文件
  编辑zabbix server的配置文件/usr/local/zabbix/etc/zabbix_server.conf,修改参数如下:


  

ListenPort=10051                                     #zabbix server监听的端口  
LogFile = /usr/local/zabbix/logs/zabbix_server.log   #日志所在路径
  
PidFile = /usr/local/zabbix/logs/zabbix_server.pid   #pid所在目录
  
DBHost = 192.168.245.133                           #数据库所在ip,默认是localhost,如果是localhost那么会根据DBSocket的socke连接mysql,开始我用localhost,报错提示老是用/var/lib/mysql/mysql.sock连接,下面我配置的是/tmp/mysql.sock
  
DBName = zabbix                                    #数据库名字,默认是zabbix
  
DBUser = zabbix                                    #数据库用户,默认是zabbix,我们上面授权的也是zabbix用户
  
DBPassword = zabbix                                  #默认数据库密码
  
DBPort = 3306                                        #默认数据库端口
  
DBSocket = /tmp/mysql.sock                           # sock 文件所在目录
  
FpingLocation = /usr/local/sbin/fping                #fping命令路径
  


  (4)配置zabbix服务
  从安装目录复制zabbix相关脚本到/etc/init.d下

  

# cp /home/software/zabbix-2.4.6/misc/init.d/fedora/core5/zabbix_* /etc/init.d/  
# chmod +x /etc/init.d/zabbix_*
  
# mkdir -p /usr/local/zabbix/logs
  
# chown -R zabbix.zabbix /usr/local/zabbix/
  
# vim /etc/init.d/zabbix_server
  
ZABBIX_BIN="/usr/local/zabbix/sbin/zabbix_server"#必须是zabbix的安装目录
  
# vim /etc/services
  
#确保有以下配置
  
zabbix-agent 10050/tcp      #Zabbix Agent
  
zabbix-agent 10050/udp      #Zabbix Agent
  
zabbix-trapper 10051/tcp      #Zabbix Trapper
  
zabbix-trapper 10051/udp      #Zabbix Trapper
  


  (5)启动和停止zabbix
  

# /etc/init.d/zabbix_server start  
Starting Zabbix Server:                                    
  
# /etc/init.d/zabbix_server stop
  
Stopping Zabbix Server:                                    
  

  (6)配置zabbix server开机自动启动
  

# chkconfig --add zabbix_server  
#chkconfig --level 35 zabbix_server on
  

  5、配置zabbix web
  (1)将zabbix web文件复制到apache web目录中
  

# mkdir -p /var/www/html/zabbix# cp -r /home/software/zabbix-2.4.6/frontends/php/* /var/www/html/zabbix
  

  (2)apache配置
  

# vim /etc/httpd/conf/httpd.conf  ServerName 192.168.245.133:80       #开启该参数并改为本机ip地址
  

  (3)php配置
  /etc/php.ini配置必须如下,否则web界面安装zabbix时会失败。
  

# vim /etc/php.ini  

  
date.timezone = Asia/Shanghai
  
max_execution_time = 300
  
post_max_size = 32M
  
max_input_time = 300
  

  (4)重新启动apache
  

#/etc/init.d/httpd restart  
Stopping httpd:                                          
  
Starting httpd:                                          
  

  (5)在浏览器输入http://192.168.245.133/zabbix进行安装,步骤如下截图:






  当然以上这些步骤完全可以手工创建zabbix.conf.php来代替。配置完成后使用默认的用户admin,以及密码zabbix即可登录zabbix。

  6、进行汉化zabbix
  在界面上点击Administration=》 Users =》 Admin =》Language =》Chinese(zh_CN),重新刷下浏览器即可。
  到此为止,zabbix服务器端就完成了。下面我们进行配置安装客户端
  7、Agent端的安装与配置
  上面我们已经安装完成服务端,但是还没有安装客户端,也就是我们真正想监控的server。对于客户端安装和服务端没有区别,只是在编译的时候只需要--enable-agent参数就行了。
  (1)安装agent软件
  

# groupadd zabbix  
# useradd -r -g zabbix -s /sbin/nologin zabbix
  
# tar zxvf zabbix-2.4.6.tar.gz
  
# cd zabbix-2.4.6
  
# ./configure --prefix=/usr/local/zabbix --enable-agent && make && make install
  
# cp misc/init.d/fedora/core5/zabbix_agentd /etc/init.d/
  

  (2)配置zabbix agent

  

# mkdir /usr/local/zabbix/logs -p  
# chown -R zabbix.zabbix /usr/local/zabbix/
  
# vim /usr/local/zabbix/etc/zabbix_agentd.conf
  
LogFile=/usr/local/zabbix/logs/zabbix_agentd.log
  
PidFile=/usr/local/zabbix/logs/zabbix_agentd.pid
  
EnableRemoteCommands=0
  
Server=192.168.245.133         #服务端ip
  
ListenPort=10050
  
StartAgents=8
  
ServerActive=192.168.245.133   #服务端ip
  
Timeout=30
  
Hostname=node1                   #主机名可以自己给,后面可以根据这个主机名添加自动发现主机
  
Include=/usr/local/zabbix/etc/zabbix_agentd.conf.d/
  
UnsafeUserParameters=1
  


  (3)配置zabbix agent系统服务启动脚本(一定要修改,否则启动报错not install)
  

# vim /etc/init.d/zabbix_agentd  ZABBIX_BIN="/usr/local/zabbix/sbin/zabbix_agentd"
  

  (4)如果有设置防火墙,则开启端口10050

  

#查看是否开启防火墙  
# service iptables status
  
iptables:未运行防火墙。
  
#如果开启了则需要执行下面命令来添加10050端口
  
# iptables -A INPUT -p tcp --dport 10050 -j ACCEPT
  
# /etc/init.d/iptables save
  
iptables: Saving firewall rules to /etc/sysconfig/iptables:
  


  (5)启动zabbix agent

  

# /etc/init.d/zabbix_agentd start  
正在启动 Zabbix Agent:                                    [确定]
  
# netstat -nltp | grep 10050
  
tcp      0      0 0.0.0.0:10050               0.0.0.0:*                   LISTEN      42035/zabbix_agentd
  
# netstat -nltp | grep mysqld
  
tcp      0      0 :::3306                     :::*                        LISTEN      31803/mysqld
  tcp      0      0 :::3307                     :::*                        LISTEN      23078/mysql
  


  (6)配置开机自启动
  

# chkconfig --add zabbix_agentd  
# chkconfig --level 35 zabbix_agentd on
  

  (7)测试zabbix agent是否正常工作(在zabbix server--192.168.245.133上做如下操作)
  

# /usr/local/zabbix/bin/zabbix_get -s 192.168.245.129 -p 10050 -k agent.ping  
1
  
# /usr/local/zabbix/bin/zabbix_get -s 192.168.245.131 -p 10050 -k agent.ping
  
1
  

  我们看到返回1表示正常工作了,返回0表示不正常。
  zabbix_get用法:

  

# ./zabbix_get --help  
Zabbix get v2.4.6 (revision 54796) (10 August 2015)
  

  
usage: zabbix_get [-hV] -s <host name or IP> [-p <port>] [-I <IP address>] -k <key>
  

  
Options:
  -s --host <host name or IP>          Specify host name or IP address of a host
  -p --port <port number>            Specify port number of agent running on the host. Default is 10050
  -I --source-address <IP address>   Specify source IP address
  

  -k --key <key of metric>             Specify key of item to retrieve value for
  

  -h --help                            Display help information
  -V --version                         Display version number
  

  
Example: zabbix_get -s 127.0.0.1 -p 10050 -k "system.cpu.load"
  


  到这里,我们就把整个mysql集群机器都部署了zabbix了,下一章我们就开始真正的mysql数据库监控之旅吧。
页: [1]
查看完整版本: zabbix实现mysql数据库的监控(一)