CentOS7下搭建zabbix监控(一)——Zabbix监控端配置

CentOS7下搭建zabbix监控(二)——Zabbix被监控端配置

(1).配置Zabbix监控Apache服务

  主机名:youxi2  IP地址:192.168.5.102

  注意:需要找一个合适的Apache监控模板

 1)安装httpd,这里为了简化步骤直接yum安装

[root@youxi2 ~]# yum -y install httpd
[root@youxi2 ~]# systemctl enable httpd  //设置开机自启
Created symlink from /etc/systemd/system/multi-user.target.wants/httpd.service to /usr/lib/systemd/system/httpd.service.

server-status,并重启httpd

[root@youxi2 ~]# vim /etc/httpd/conf/httpd.conf
EnableSendfile on  //这是第348行,在这行下面添加如下标签
<location /server-status>
  SetHandler server-status
  Order allow,deny
  Allow from localhost 192.168.5.0/24
</location>
[root@youxi2 ~]# systemctl restart httpd

  还可以在/etc/httpd/conf.d/目录下创建一个.conf格式的文件,将配置写入其中。最后重启httpd。

  注意:有时候127.0.0.1不生效会导致zapache不支持,可以将IP地址改成all尝试。

 3)如果防火墙是打开的,记得添加端口号

[root@youxi2 ~]# firewall-cmd --permanent --zone=public --add-port=80/tcp
success
[root@youxi2 ~]# firewall-cmd --reload 
success
[root@youxi2 ~]# firewall-cmd --permanent --zone=public --list-ports
10050/tcp 80/tcp

 4)Web验证Apache打开server-status

zabbix监控redis grafana模版 zabbix监控apache_mysql

 5)下载模板文件

  模板文件需要在Windows和CentOS上各留一份,地址:https://github.com/lorf/zapache/archive/master.zip。然后解压

  由于下载的是zip格式文件,所以需要unzip程序

[root@youxi2 ~]# yum -y install unzip

  安装完成后解压文件

[root@youxi2 ~]# unzip zapache-master.zip 
Archive:  zapache-master.zip
24a764b2e224f9b8d0a6bc94dcadd7568b2fe650
   creating: zapache-master/
  inflating: zapache-master/README.md  
  inflating: zapache-master/httpd-server-status.conf.sample  
  inflating: zapache-master/userparameter_zapache.conf.sample  
  inflating: zapache-master/zapache  
  inflating: zapache-master/zapache-template-active.xml  
  inflating: zapache-master/zapache-template.xml
[root@youxi2 ~]# ls zapache-master/
httpd-server-status.conf.sample    zapache
README.md                          zapache-template-active.xml
userparameter_zapache.conf.sample  zapache-template.xml

  文件说明:

   httpd-server-status.conf.sample  用于配置httpd开启server-status

   zapache、userparameter_zapache.conf.sample  关键的脚本和配置文件

   zapache-template-active.xml、zapache-template.xml  模板文件(active是动作,是触发器模板)

 6)修改配置文件和脚本

[root@youxi2 ~]# cp zapache-master/zapache /usr/local/bin/  //拷贝脚本
[root@youxi2 ~]# chmod +x /usr/local/bin/zapache  //给脚本添加执行权限
[root@youxi2 ~]# cp zapache-master/userparameter_zapache.conf.sample /usr/local/zabbix/etc/zabbix_agentd.conf.d/userparameter_zapache.conf  //拷贝配置文件,并重命名
[root@youxi2 ~]# vim /usr/local/zabbix/etc/zabbix_agentd.conf.d/userparameter_zapache.conf
UserParameter=zapache[*],/usr/local/bin/zapache \$1  //指向脚本文件
[root@youxi2 ~]# vim /usr/local/zabbix/etc/zabbix_agentd.conf
# Include=/usr/local/etc/zabbix_agentd.userparams.conf  //第263~265行
Include=/usr/local/zabbix/etc/zabbix_agentd.conf.d/  //去除注释,修改并启用该目录
# Include=/usr/local/etc/zabbix_agentd.conf.d/*.conf

 7)Web端导入模板

   A.选择配置中的模板,点击导入

zabbix监控redis grafana模版 zabbix监控apache_apache_02

   B.选择导入文件,点击导入,就成功导入这个模板了。

zabbix监控redis grafana模版 zabbix监控apache_Apache_03

 8)Web端关联模板(给现有的主机添加新的模板)

   A.选择配置中的主机,点击任意主机名称

zabbix监控redis grafana模版 zabbix监控apache_mysql_04

   B.选择模板,选中Template App Apache Web Server zapache模板,添加并更新

zabbix监控redis grafana模版 zabbix监控apache_Apache_05

   C.之后可以在监测的图形中选择Apache相关检测项

zabbix监控redis grafana模版 zabbix监控apache_apache_06

    也可以在监测中的最新数据选择Apache相关监控项构成图形

zabbix监控redis grafana模版 zabbix监控apache_Apache_07

(2).配置Zabbix监控Mysql服务

  主机:youxi2  IP地址:192.168.5.102

  和Apache一样需要先找一个监控模板,不过Zabbix默认提供了Mysql的监控模板。

 1)安装Mysql

  具体查看:二进制包安装Mysql

  mysql安装目录/usr/local/mysql/,数据目录/usr/local/mysql/data/,mysql的root用户密码为123456。启动并设置开机自启。

 2)数据库用户授权

   创建用户和授予usage权限是一样的效果。

[root@youxi2 ~]# mysql -uroot -p123456
mysql> create user 'zabbix'@'192.168.5.%' identified by '123456';  //创建用户zabbix
Query OK, 0 rows affected (0.00 sec)

mysql> show grants for 'zabbix'@'192.168.5.%';  //查看用户zabbix的权限
+----------------------------------------------+
| Grants for zabbix@192.168.5.%                |
+----------------------------------------------+
| GRANT USAGE ON *.* TO 'zabbix'@'192.168.5.%' |  //usage表示只有登录和查询information_schema的权限
+----------------------------------------------+
1 row in set (0.00 sec)

mysql> grant usage on *.* to 'zabbix2'@'192.168.5.%' identified by '123456';  //授权zabbix2
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql> show grants for 'zabbix2'@'192.168.5.%';  //查看用户zabbix2的权限
+-----------------------------------------------+
| Grants for zabbix2@192.168.5.%                |
+-----------------------------------------------+
| GRANT USAGE ON *.* TO 'zabbix2'@'192.168.5.%' |
+-----------------------------------------------+
1 row in set (0.00 sec)

mysql> flush privileges;  //刷新
Query OK, 0 rows affected (0.00 sec)

 3)修改配置文件,并重启Zabbix Agent

[root@youxi2 ~]# cp /usr/local/src/zabbix-3.4.3/conf/zabbix_agentd/userparameter_mysql.conf /usr/local/zabbix/etc/zabbix_agentd.conf.d/
[root@youxi2 ~]# vim /usr/local/zabbix/etc/zabbix_agentd.conf.d/userparameter_mysql.conf  //HOME参数的路径必须与下方编辑的.my.cnf路径必须一致
UserParameter=mysql.status[*],echo "show global status where Variable_name='$1';" | HOME=/usr/local/zabbix/etc mysql -N | awk '{print $$2}'  //第5行
UserParameter=mysql.size[*],bash -c 'echo "select sum($(case "$3" in both|"") echo "data_length+index_length";; data|index) echo "$3_length";; free) echo "data_free";;
 esac)) from information_schema.tables$([[ "$1" = "all" || ! "$1" ]] || echo " where table_schema=\"$1\"")$([[ "$2" = "all" || ! "$2" ]] || echo "and table_name=\"$2\"");"
 | HOME=/usr/local/zabbix/etc/ mysql -N'  //第15行
UserParameter=mysql.ping,HOME=/usr/local/zabbix/etc mysqladmin ping | grep -c alive  //第17行
[root@youxi2 ~]# vim /usr/local/zabbix/etc/.my.cnf  //配置数据库与zabbix连接文件。与上方userparameter_mysql.conf修改路径保持一致
#Zabbix Agent
[mysql]
host=localhost
user=zabbix
password=123456
socket=/usr/local/mysql/mysql.sock

[mysqladmin]
host=localhost
user=zabbix
password=123456
socket=/usr/local/mysql/mysql.sock
[root@youxi2 ~]# vim /usr/local/zabbix/etc/zabbix_agentd.conf
# Include=/usr/local/etc/zabbix_agentd.userparams.conf  //第263~265行,三个里面有且仅有一个开启
Include=/usr/local/zabbix/etc/zabbix_agentd.conf.d/  //去除注释,修改并启用该目录
# Include=/usr/local/etc/zabbix_agentd.conf.d/*.conf
[root@youxi2 ~]# /etc/init.d/zabbix_agentd restart  //重启 Restarting zabbix_agentd (via systemctl): [ 确定 ]

 4)在监控端测试

  如果提示如下错误,需要到被监控端(youxi2)将mysql和mysqladmin做一个软链接到/usr/bin下(明明有环境变量,也可以在youxi2上直接调用,但它就不认)

[root@youxi1 ~]# /usr/local/zabbix/bin/zabbix_get -s192.168.5.102 -p10050 -k mysql.status[Uptime]
sh: mysql: 未找到命令
[root@youxi1 ~]# /usr/local/zabbix/bin/zabbix_get -s192.168.5.102 -p10050 -k mysql.ping
sh: mysqladmin: 未找到命令

  做一个软链接

[root@youxi2 ~]# ln -s /usr/local/mysql/bin/mysql /usr/bin/
[root@youxi2 ~]# ln -s /usr/local/mysql/bin/mysqladmin /usr/bin/

  再次测试成功

[root@youxi1 ~]# /usr/local/zabbix/bin/zabbix_get -s192.168.5.102 -p10050 -k mysql.status[Uptime]
414
[root@youxi1 ~]# /usr/local/zabbix/bin/zabbix_get -s192.168.5.102 -p10050 -k mysql.ping
1

 5)Web端关联模板

  A.选择配置中的主机,点击任意主机名称

zabbix监控redis grafana模版 zabbix监控apache_mysql_08

  B.选择模板,选中Template DB MySQL模板,添加并更新

zabbix监控redis grafana模版 zabbix监控apache_mysql_09

  C.之后就可以在监测中查看了。