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代理服务器。
【部署环境说明】:

zabbix监控docker jvm zabbix监控数据库_zabbix

1、环境准备(在zabbix server上)

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

[root@monitor ~]# yum install httpd php -y

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

[root@monitor ~]# chkconfig httpd on
[root@monitor ~]# /etc/init.d/httpd start

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

[root@monitor ~]#  yum install  gcc net-snmp-devel  mysql-devel curl-devel perl-DBI php-gd php-mysql php-bcmath php-mbstring php-xml  -y

(4)创建zabbix运行账户

[root@monitor ~]# groupadd zabbix
[root@monitor ~]# useradd -r -g zabbix -s /sbin/nologin zabbix

2、安装zabbix server(192.168.245.133)

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

3、安装fping

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

[root@monitor software]# tar zxvf fping-3.13.tar.gz
[root@monitor software]# cd fping-3.13
[root@monitor fping-3.13]# ./configure && make install
[root@monitor fping-3.13]# chown root.zabbix /usr/local/sbin/fping
[root@monitor fping-3.13]# 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@'%' identified by 'zabbix';
Query OK, 0 rows affected (0.02 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

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

[root@monitor software]# cd /home/software/zabbix-2.4.6/database/mysql/
[root@monitor mysql]# /data/mysql/bin/mysql -uzabbix -pzabbix zabbix <schema.sql
[root@monitor mysql]# /data/mysql/bin/mysql -uzabbix -pzabbix zabbix <images.sql 
[root@monitor mysql]# /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下

[root@monitor core5]# cp /home/software/zabbix-2.4.6/misc/init.d/fedora/core5/zabbix_* /etc/init.d/
[root@monitor core5]# chmod +x /etc/init.d/zabbix_*
[root@monitor core5]# mkdir -p /usr/local/zabbix/logs
[root@monitor core5]# chown -R zabbix.zabbix /usr/local/zabbix/
[root@monitor core5]# vim /etc/init.d/zabbix_server
ZABBIX_BIN="/usr/local/zabbix/sbin/zabbix_server"  #必须是zabbix的安装目录
[root@monitor core5]# 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

[root@monitor logs]# /etc/init.d/zabbix_server start
Starting Zabbix Server:                                    [  OK  ]
[root@monitor logs]# /etc/init.d/zabbix_server stop
Stopping Zabbix Server:                                    [  OK  ]

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

[root@monitor logs]# chkconfig --add zabbix_server
[root@monitor logs]#  chkconfig --level 35 zabbix_server on

5、配置zabbix web

(1)将zabbix web文件复制到apache web目录中

[root@monitor html]# mkdir -p /var/www/html/zabbix
[root@monitor php]# cp -r /home/software/zabbix-2.4.6/frontends/php/* /var/www/html/zabbix

(2)apache配置

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

(3)php配置

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

[root@monitor html]# vim /etc/php.ini

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

(4)重新启动apache

[root@monitor html]#  /etc/init.d/httpd restart
Stopping httpd:                                            [  OK  ]
Starting httpd:                                            [  OK  ]

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

zabbix监控docker jvm zabbix监控数据库_mysql监控_02


zabbix监控docker jvm zabbix监控数据库_zabbix_03


zabbix监控docker jvm zabbix监控数据库_zabbix_04


zabbix监控docker jvm zabbix监控数据库_mysql_05


zabbix监控docker jvm zabbix监控数据库_zabbix监控docker jvm_06


zabbix监控docker jvm zabbix监控数据库_mysql_07

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

 

zabbix监控docker jvm zabbix监控数据库_zabbix_08

 6、进行汉化zabbix

在界面上点击Administration=》 Users =》 Admin =》Language =》Chinese(zh_CN),重新刷下浏览器即可。

到此为止,zabbix服务器端就完成了。下面我们进行配置安装客户端

7、Agent端的安装与配置

上面我们已经安装完成服务端,但是还没有安装客户端,也就是我们真正想监控的server。对于客户端安装和服务端没有区别,只是在编译的时候只需要--enable-agent参数就行了。

(1)安装agent软件

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

(2)配置zabbix agent

[root@node2 zabbix-2.4.6]# mkdir /usr/local/zabbix/logs -p
[root@node1 zabbix-2.4.6]# chown -R zabbix.zabbix /usr/local/zabbix/
[root@node1 zabbix-2.4.6]# 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)

[root@node1 zabbix-2.4.6]# vim /etc/init.d/zabbix_agentd
    ZABBIX_BIN="/usr/local/zabbix/sbin/zabbix_agentd"

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

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

(5)启动zabbix agent

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

(6)配置开机自启动

[root@node2 sbin]# chkconfig --add zabbix_agentd
[root@node2 sbin]# chkconfig --level 35 zabbix_agentd on

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

[root@monitor bin]# /usr/local/zabbix/bin/zabbix_get -s 192.168.245.129 -p 10050 -k agent.ping
1
[root@monitor bin]# /usr/local/zabbix/bin/zabbix_get -s 192.168.245.131 -p 10050 -k agent.ping
1

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

zabbix_get用法:

[root@monitor bin]# ./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[all,avg1]"

到这里,我们就把整个mysql集群机器都部署了zabbix了,下一章我们就开始真正的mysql数据库监控之旅吧。