作者简介
马听,多年 DBA 实战经验,对 MySQL、 Redis、ClickHouse 等数据库有一定了解,专栏《一线数据库工程师带你深入理解 MySQL》、《Redis 运维实战》作者。
朋友们,你们是否好奇目前 MySQL 主流的监控方案是什么?“悦专栏”趁这次写监控专题的机会,在文末增加了 MySQL 监控方案的投票,欢迎各位朋友参与。
这是《MySQL 监控》系列文章的第 3 节,之前我们讲解了“Prometheus Grafana 监控 MySQL”和“PMM 监控 MySQL”,这一节内容来聊聊 Zabbix 的部署以及配置 Zabbix 监控 MySQL。目前《MySQL 监控》系列文章在公众号“悦专栏”中持续更新,欢迎关注。
1 架构图
如上图,通过 Zabbix Agent 获取 MySQL 的监控数据(需要结合一些脚本和命令,在本节的后面会提到具体配置方法)。将获得的监控数据传到 Zabbix Server 中,最终通过 Zabbix Web 展示出来。
2 实验环境介绍
测试的环境如下:
作用 | IP 地址 | 主机名 | 操作系统 | 版本 |
---|---|---|---|---|
Zabbix Server | 192.168.1.5 | node1 | CentOS 7.8 | zabbix-server-mysql-4.0.27 |
Zabbix 数据库 | 192.168.1.6 | node2 | CentOS 7.8 | MySQL 8.0.23 |
MySQL 机器(Zabbix Agent) | 192.168.1.7 | node3 | CentOS 7.8 | MySQL 8.0.23 |
3 安装 Zabbix Server
在 node1 机器上部署 Zabbix Server,具体步骤如下:
添加 Zabbix 存储库
代码语言:javascript复制rpm -ivh http://repo.zabbix.com/zabbix/4.0/rhel/7/x86_64/zabbix-release-4.0-1.el7.noarch.rpm
代码语言:javascript复制启用 rpm 存储库
代码语言:javascript复制yum-config-manager --enable rhel-7-server-optional-rpms
代码语言:javascript复制安装 Zabbix server
代码语言:javascript复制yum install -y zabbix-server-mysql
代码语言:javascript复制安装 Zabbix 前端
代码语言:javascript复制yum install -y zabbix-web-mysql
4 配置 Zabbix 的数据库
登陆 node2 机器上的 MySQL ,创建 zabbix 数据库和用户:
代码语言:javascript复制mysql> create database zabbix character set utf8 collate utf8_bin;
Query OK, 1 row affected (0.00 sec)
mysql> create user 'zabbix_rw'@'%' IDENTIFIED WITH mysql_native_password BY 'Zabbix@123456' ;
Query OK, 0 rows affected (0.07 sec)
mysql> grant all privileges on zabbix.* to zabbix_rw@'%';
Query OK, 0 rows affected (0.00 sec)
登陆 node1 机器,导入 MySQL 初始化 SQL 语句:
代码语言:javascript复制zcat /usr/share/doc/zabbix-server-mysql*/create.sql.gz | mysql -uzabbix_rw -p'Zabbix@123456' zabbix -h192.168.1.6
5 编辑配置文件
在 node1 机器上,编辑 Zabbix Server 的配置文件 /etc/zabbix/zabbix_server.conf:
代码语言:javascript复制LogFile=/var/log/zabbix/zabbix_server.log
LogFileSize=0
PidFile=/var/run/zabbix/zabbix_server.pid
SocketDir=/var/run/zabbix
DBHost=192.168.1.6
DBName=zabbix
DBUser=zabbix_rw
DBPassword=Zabbix@123456
SNMPTrapperFile=/var/log/snmptrap/snmptrap.log
Timeout=4
AlertScriptsPath=/usr/lib/zabbix/alertscripts
ExternalScripts=/usr/lib/zabbix/externalscripts
LogSlowQueries=3000
编辑 PHP 配置文件 /etc/php.ini:
在 ;date.timezone = 下一行添加:
代码语言:javascript复制date.timezone = Asia/Shanghai
6 启动 Zabbix Server
在 node1 机器上启动 Zabbix Server
设置 zabbix-server 开机启动
代码语言:javascript复制systemctl enable zabbix-server
启动 zabbix-server
代码语言:javascript复制systemctl start zabbix-server
代码语言:javascript复制设置 Apache 开启启动
代码语言:javascript复制systemctl enable httpd
代码语言:javascript复制启动 Apache 服务
代码语言:javascript复制systemctl start httpd
7 Zabbix WEB 界面初始化
登陆 http://192.168.1.5/zabbix
点击 “Next step”,可进入如下界面:
点击 “Next step”,可进入如下界面,修改 MySQL 的连接信息:
点击 “Next step”,可进入如下界面:
点击 “Next step”,可进入如下界面:
点击 “Next step”,可进入如下界面:
点击 "Finish",可跳转到 zabbix 的登陆界面:
默认用户名为 Admin,密码为 zabbix。登陆后,可进入到 Zabbix 的主页面,如下图:
到这一步,表示 Zabbx Server 的安装已经完成。
8 安装 Zabbix Agent
在 node3 上安装 Zabbix Agent:
安装 Zabbix Agent 包
代码语言:javascript复制yum install zabbix-agent
代码语言:javascript复制将 zabbix-agent 加入开机启动
代码语言:javascript复制systemctl enable zabbix-agent
代码语言:javascript复制启动 Zabbix Agent
代码语言:javascript复制systemctl start zabbix-agent
9 安装 Percona 插件
在 node3 上安装 Percona 插件,登录 Percona Monitoring Plugins 下载界面:https://www.percona.com/downloads/percona-monitoring-plugins/。选择对应的版本,进行下载。
将下载后的 rpm 包传到 Agent 机器上,进行 percona zabbix 插件的安装:
代码语言:javascript复制yum install -y percona-zabbix-templates-1.1.8-1.noarch.rpm
cp /var/lib/zabbix/percona/templates/userparameter_percona_mysql.conf /etc/zabbix/zabbix_agentd.d/
yum -y install php php-mysql
10 在 Agent 创建 Zabbix 监控用户
在 node3 上登陆 MySQL,创建监控用户:
代码语言:javascript复制create user 'zabbix'@'localhost' identified with mysql_native_password by 'Zabbix@123';
GRANT SELECT, PROCESS, SUPER, REPLICATION CLIENT ON *.* TO 'zabbix'@'localhost';
11 修改配置文件
在 node3 上,编辑 /etc/zabbix/zabbix_agentd.conf 文件,修改下面两行:
代码语言:javascript复制Server= 192.168.1.5
Hostname=192.168.1.7
其中: Server 为 Zabbix Server 的 IP; Hostname 为本机 IP。
重启 zabbix agent
代码语言:javascript复制systemctl restart zabbix-agent
编辑配置文件 /var/lib/zabbix/percona/scripts/ss_get_mysql_stats.php.cnf
代码语言:javascript复制<?php
$mysql_user = 'zabbix';
$mysql_pass = 'Zabbix@123';
编辑配置文件 ~zabbix/.my.cnf
代码语言:javascript复制[client]
user = zabbix
password = Zabbix@123
12 测试监控
在 node3 上执行:
代码语言:javascript复制/var/lib/zabbix/percona/scripts/get_mysql_stats_wrapper.sh gg
在 node1 上执行:
代码语言:javascript复制yum install zabbix-get -y
zabbix_get -s 192.168.1.7 -p10050 -k "agent.ping"
zabbix_get -s 192.168.1.7 -p10050 -k "MySQL.Key-read-requests"
如果都有返回值,则表示客户端部署正常。
删除临时文件(该文件为临时存放监控数据的文件,测试时,该文件的属组为 root,如果不删除,会导致 zabbix 用户无权限取到监控数据):
代码语言:javascript复制rm /tmp/localhost-mysql_cacti_stats.txt -rf
13 导入 Percona 模板
在客户端机器:
代码语言:javascript复制cd /var/lib/zabbix/percona/templates
获取到 zabbix_agent_template_percona_mysql_server_ht_2.0.9-sver1.1.8.xml 文件。
在 Zabbix 的 web 界面上,点击Configuration -> Templates -> Import 导入
进入以下界面,点击选择文件:
选择完文件后,点击“Import”:
如下图,如果出现“Imported successfully”,则说明导入成功。
Configuration-->Templates,输入关键字 “percona”,则可以看到新导入的模板 “Template Perconal MySQL Server”:
14 Zabbix web 增加主机配置
Configuration-->Hosts-->Create host,如下:
点击上图的“Create host”,进入下图,其中 Host name 填写被监控机器的可区分名字,Agent interfaces 中的 IP address 填被监控机器的 IP:
点击“Templates”,增加下图中对应的两个选项。
15 查看监控数据
Monitoring-->Graphs,Host 选择这次新增的主机名,Graph 选择一个监控项,看是否有数据:
到这里,使用 Zabbix 监控 MySQL 的内容就讲完了。
专栏《MySQL 监控》系列文章推荐
第01期:Prometheus Grafana 监控 MySQL
第02期:PMM 监控 MySQL