关于Anemometer图形化显示MySQL慢日志的工具搭建及使用的详细介绍


Posted in PHP onJuly 13, 2020

介绍:Anemometer 是一个图形化显示MySQL慢日志的工具。结合pt-query-digest,Anemometer可以很轻松的帮你去分析慢查询日志,让你很容易就能找到哪些SQL需要优化

This is the Box Anemometer, the MySQL Slow Query Monitor. This tool is used to analyze slow query logs collected from MySQL instances to identify problematic queries

官方网站:https://github.com/box/Anemometer

环境概况

以写此文章时 percona-toolkit最新的版本3.0.10为例
mysql数据库对应版本为5.7.21,二进制安装
http和php均是系统CentOS Linux release 7.4.1708 (Core)自带版本

需要安装的步骤如下:

1.percona-toolkit工具的安装

2.php web环境的搭建安装

3.Anemometer并配置

4.导入慢查询日志

5.访问界面,查看慢查询

6.其他相关和问题解决

0. 整体的架构

关于Anemometer图形化显示MySQL慢日志的工具搭建及使用的详细介绍

1. percona-toolkit工具的安装

安装目的:pt-query-digest是percona-toolkit里面一个工具,其作用就是分析慢查询日志,将MySQL慢查询日志进行统计并友好的显示出来

下载地址:https://www.percona.com/downloads/percona-toolkit/

安装方式(rpm):

1、下载包,wget https://www.percona.com/downloads/percona-toolkit/3.0.10/binary/redhat/7/x86_64/percona-toolkit-3.0.10-1.el7.x86_64.rpm

2、安装依赖,yum install perl-DBI perl-DBD-MySQL perl-IO-Socket-SSL perl-Digest-MD5 -y

3、正式安装,rpm -ivh percona-toolkit-3.0.10-1.el7.x86_64.rpm

4、安装完毕验证,pt-query-digest --version pt-query-digest 3.0.10

安装方式(tar二进制)

1、下载包,wget https://www.percona.com/downloads/percona-toolkit/3.0.10/binary/tarball/percona-toolkit-3.0.10_x86_64.tar.gz

2、安装依赖,yum install perl-DBI perl-DBD-MySQL perl-IO-Socket-SSL perl-Digest-MD5 -y

3、解压包,tar xf percona-toolkit-3.0.10_x86_64.tar.gz

4、直接使用工具, ./percona-toolkit-3.0.10/bin/pt-query-digest --version
pt-query-digest 3.0.10

2. php web环境的搭建

安装目的:Anemometer需要依赖
LAMP环境LAMP环境的安装:
1、安装apache,yum install httpd httpd-devel -y
2、安装php,yum install php php-mysql php-common php-bcmath php-dba php-cli php-gd php-mbstring php-mcrypt php-devel php-xml php-pdo -y
3、修改时区,vim /etc/php.ini,修改为 date.timezone = PRC

LAMP环境的启动:
1、启动,systemctl start httpd
2、关闭,systemctl stop httpd
3、重启,systemctl restart httpd
4、查看,systemctl status httpd

3. 安装Anemometer并配置

1、下载安装:
安装目的:安装Anemometer应用
下载地址:https://github.com/box/Anemometer
下载包:git clone https://github.com/box/Anemometer.git
移动到对应路径:mv Anemometer /var/www/html/anemometer
2、目标慢查询数据库上需要授予Anemometer主机对应的权限
1、目的,用于分析目标慢查询数据库explain执行计划
2、授权,grant select on *.* to 'anemometer'@'$ip' identified by '123456';flush privileges;($ip为Anemometer主机对应ip地址)
3、修改配置文件增加explain读取用户密码信息 cp conf/sample.config.inc.php conf/config.inc.php vim conf/config.inc.php\\

关于Anemometer图形化显示MySQL慢日志的工具搭建及使用的详细介绍

4、修改配置文件指向数据源文件,vim conf/datasource_localhost.inc.php,当然也可以直接vim conf/config.inc.php

关于Anemometer图形化显示MySQL慢日志的工具搭建及使用的详细介绍

5、初始化数据源的数据库表的配置,mysql -uroot -p123456 -h127.0.0.1 -P5700 < install.sql,每个datasource源头可以对应不同的数据库database(修改install.sql的内容)

关于Anemometer图形化显示MySQL慢日志的工具搭建及使用的详细介绍

4. 导入慢查询日志

1、慢查询主机推送格式

For pt-query-digest version < 2.2
$ pt-query-digest --user=anemometer --password=superSecurePass \
--review h=db.example.com,D=slow_query_log,t=global_query_review \
--review-history h=db.example.com,D=slow_query_log,t=global_query_review_history \
--no-report --limit=0% \ 
--filter=" \$event->{Bytes} = length(\$event->{arg}) and \$event->{hostname}=\"$HOSTNAME\"" \ 
/var/lib/mysql/db.example.com-slow.log

For pt-query-digest version >= 2.2
$ pt-query-digest --user=anemometer --password=superSecurePass \
--review h=db.example.com,D=slow_query_log,t=global_query_review \
--history h=db.example.com,D=slow_query_log,t=global_query_review_history \
--no-report --limit=0% \ 
--filter=" \$event->{Bytes} = length(\$event->{arg}) and \$event->{hostname}=\"$HOSTNAME\"" \ 
/var/lib/mysql/db.example.com-slow.log

2、慢查询主机推动脚本示例

#config anemometer server, the purpose is to push slow query to the remote anemometer server and store it.
anemometer_host="127.0.0.1"
anemometer_user="root"
anemometer_password="123456"
anemometer_port=5700
anemometer_db="slow_query_log"

#config mysql server, the purpose is to get the path of the slow query log.
mysql_client="/usr/local/mysql-5.7.21/bin/mysql"
mysql_user="root"
mysql_password="123456"
mysql_socket="/tmp/mysql_5700.sock"
mysql_port=5700

#config slowqury dir to cd, and then delete the expired slow query file.
slowquery_dir="/data/mysql_$mysql_port/"

#get the path of the slow query log.
slowquery_file=`$mysql_client -u$mysql_user -p$mysql_password -S $mysql_socket -e "show variables like 'slow_query_log_file'"|grep log|awk '{print $2}'`
pt_query_digest="/data/percona-toolkit-3.0.10/bin/pt-query-digest"

#collect mysql slowquery log into lepus database.
$pt_query_digest --user=$anemometer_user --password=$anemometer_password --port=$anemometer_port --review h=$anemometer_host,D=$anemometer_db,t=global_query_review --history h=$anemometer_host,D=$anemometer_db,t=global_query_review_history --no-report --limit=0% --filter=" \$event->{Bytes} = length(\$event->{arg}) and \$event->{hostname}=\"$HOSTNAME:$mysql_port\"" $slowquery_file

#generate a new slow query log, the below is generate a new slow file per hour.
tmp_log=`$mysql_client -u$mysql_user -p$mysql_password -S $mysql_socket -e "select concat('$slowquery_dir','slowquery_',date_format(now(),'%Y%m%d%H'),'.log');"|grep log|sed -n -e '2p'`

#use new slow file to config mysql slowquery
$mysql_client -u$mysql_user -p$mysql_password -S $mysql_socket -e "set global slow_query_log = 0;set global slow_query_log_file = '$tmp_log';"
$mysql_client -u$mysql_user -p$mysql_password -S $mysql_socket -e "set global slow_query_log = 1; "

#delete slow query file before 2 days
cd $slowquery_dir
/usr/bin/find ./ -name 'slowquery_*.log' -mtime +2|xargs rm -rf ;

####END####

5. 访问界面,查看慢查询

http://$ip/anemometer/ ($ip为Anemometer主机对应ip地址)

关于Anemometer图形化显示MySQL慢日志的工具搭建及使用的详细介绍

关于Anemometer图形化显示MySQL慢日志的工具搭建及使用的详细介绍

关于Anemometer图形化显示MySQL慢日志的工具搭建及使用的详细介绍

6、其他相关和问题解决

1、对于anemometer的主机上,需要进行慢查询主机hostname和ip的映射(修改/etc/hosts进行配置),目的在于慢查询explain执行计划的目标主机解析
#collect mysql slowquery log into lepus database步骤中,$HOSTNAME:$mysql_port
数据库存取的格式,hostname_max类似这种,cnwangdawei:5700
2、中文乱码的问题,在#collect mysql slowquery log into lepus database步骤中添加 --charset=utf8
3、慢查询主机数据库是5.7版本的数据库,可能出现界面ts_cnt不显示,替换percona toolkit为新版本,2.x.x -----> 3.x.x
4、表结构和状态字符集显示乱码,添加mysqli的字符集设定,vim /var/www/html/anemometer/lib/QueryExplain.php
新增(194行后增加),$this->mysqli->query("set names utf8");

关于Anemometer图形化显示MySQL慢日志的工具搭建及使用的详细介绍

以上就是关于Anemometer图形化显示MySQL慢日志的工具搭建及使用的详细介绍的详细内容,更多关于Anemometer图形化显示MySQL慢日志的工具搭建的资料请关注三水点靠木其它相关文章!

PHP 相关文章推荐
十天学会php之第四天
Oct 09 PHP
按上下级层次关系输出内容的PHP代码
Jul 17 PHP
PHP MemCached高级缓存配置图文教程
Aug 05 PHP
php实现的一个很好用HTML解析器类可用于采集数据
Sep 23 PHP
PHP字符串word末字符实现大小写互换的方法
Nov 10 PHP
php获取Google机器人访问足迹的方法
Apr 15 PHP
php实现curl模拟ftp上传的方法
Jul 29 PHP
php获取远程文件的内容和大小
Nov 03 PHP
php微信浏览器分享设置以及回调详解
Aug 01 PHP
PHP简单实现上一页下一页功能示例
Sep 14 PHP
smarty模板的使用方法实例分析
Sep 18 PHP
Thinkphp5.0 框架视图view的比较标签用法分析
Oct 12 PHP
通过实例解析PHP数据类型转换方法
Jul 11 #PHP
PHP var关键字相关原理及使用实例解析
Jul 11 #PHP
PHP手机号码及邮箱正则表达式实例解析
Jul 11 #PHP
基于PHP实现短信验证码发送次数限制
Jul 11 #PHP
PHP连接MySQL数据库操作代码实例解析
Jul 11 #PHP
PHP如何使用cURL实现Get和Post请求
Jul 11 #PHP
使用Rancher在K8S上部署高性能PHP应用程序的教程
Jul 10 #PHP
You might like
2021年最新CPU天梯图
2021/03/04 数码科技
一篇不错的PHP基础学习笔记
2007/03/18 PHP
php获取错误信息的方法
2015/07/17 PHP
ajax上传时参数提交不更新等相关问题
2012/12/11 Javascript
js 实现 input type=&quot;file&quot; 文件上传示例代码
2013/08/07 Javascript
14款NodeJS Web框架推荐
2014/07/11 NodeJs
js+css实现有立体感的按钮式文字竖排菜单效果
2015/09/01 Javascript
Bootstrap教程JS插件弹出框学习笔记分享
2016/05/17 Javascript
javascript之Array 数组对象详解
2016/06/07 Javascript
AngularJS 基础ng-class-even指令用法
2016/08/01 Javascript
Vue.js快速入门教程
2016/09/07 Javascript
js仿支付宝多方框输入支付密码效果
2016/09/27 Javascript
最实用的jQuery分页插件
2016/10/09 Javascript
webpack入门+react环境配置
2017/02/08 Javascript
数组Array的一些方法(总结)
2017/02/17 Javascript
JS实现带阴历的日历功能详解
2019/01/24 Javascript
详解 微信小程序开发框架(MINA)
2019/05/17 Javascript
Vue filter 过滤当前时间 实现实时更新效果
2019/12/20 Javascript
jQuery操作元素的内容和样式完整实例分析
2020/01/10 jQuery
[53:03]Optic vs TNC 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/18 DOTA
python函数返回多个值的示例方法
2013/12/04 Python
python计算最小优先级队列代码分享
2013/12/18 Python
Python内置的HTTP协议服务器SimpleHTTPServer使用指南
2016/03/30 Python
django+xadmin+djcelery实现后台管理定时任务
2018/08/14 Python
Python导入数值型Excel数据并生成矩阵操作
2020/06/09 Python
Django扫码抽奖平台的配置过程详解
2021/01/14 Python
css3 中实现炫酷的loading效果
2019/04/26 HTML / CSS
HTML5 canvas基本绘图之绘制矩形
2016/06/27 HTML / CSS
英国儿童家具专卖店:GLTC
2016/09/24 全球购物
中科前程Java笔试题
2016/11/20 面试题
办公室主任岗位职责
2013/11/08 职场文书
婚假请假条格式及范文
2014/04/10 职场文书
2014年社区个人工作总结
2014/12/02 职场文书
大班上学期个人总结
2015/02/13 职场文书
党校团干班培训心得体会
2016/01/06 职场文书
Linux中Nginx的防盗链和优化的实现代码
2021/06/20 Servers