使用Anemometer基于pt-query-digest将MySQL慢查询可视化

时间:2022-09-21 22:00:57

最近玩MySQL,发现了一个很不错的工具,可以把MySQL慢查询可视化,方便我们去找出和分析慢询语句,搭建的步骤不多,但网上详细教程比较少,说得也不够详细,一不小心,估计得蛋痛一会,哈哈

Percona Toolkit 是一组高级的命令行工具,用来管理 MySQL 和系统任务,主要包括:
1、验证主节点和复制数据的一致性
2、有效的对记录行进行归档
3、找出重复的索引
4、总结 MySQL 服务器
5、从日志和 tcpdump 中分析查询
6、问题发生时收集重要的系统信息

一、PT安装:

方法一:rpm包安装

[root ~]$ wget http://www.percona.com/downloads/percona-toolkit/LATEST/RPM/percona-toolkit-2.2.12-1.noarch.rpm
[root ~]$ yum install perl-IO-Socket-SSL perl-DBD-MySQL perl-Time-HiRes -y
[root ~]$ rpm -ivh percona-toolkit-2.2.-.noarch.rpm
warning: percona-toolkit-2.2.-.noarch.rpm: Header V4 DSA/SHA1 Signature, key ID cd2efd2a: NOKEY
Preparing... ########################################### [%]
:percona-toolkit ########################################### [%]

如果yum 安装不上依赖包,则检查下epel源,也可以查看http://www.cnblogs.com/xuanzhi201111/p/4040761.html去解决!

方法二:源码包安装

[root ~]$ wget http://www.percona.com/downloads/percona-toolkit/2.2.12/deb/percona-toolkit_2.2.12.tar.gz
[root ~]$tar zxf percona-toolkit_2.2.12.tar.gz
[root ~]$cd percona-toolkit_2.2.12
[root percona-toolkit-2.2.]$perl Makefile.PL
[root percona-toolkit-2.2.]$ make && make install

工具安装目录在:/usr/local/bin

二、下载Anemometer
官网:https://github.com/box/Anemometer

三、安装httpd php,php版本要大于5.3,否则就报错,除此之外还需要:bcmath,php必须支持pdo_mysql、php_mysqli模块,下面我们来安装一下:

[root ~]$ yum install  httpd php *bcmath* *mysqli*  -y

如果epel源像以下的,说明是旧的,该源没有php_mysqli相关模块的

[root yum.repos.d]$ rpm -q epel-release
epel-release--.noarch

以下版本才有:

[root yum.repos.d]$ rpm -q epel-release
epel-release--.noarch

我的mysql早已经安装好了的,这里就不多说了

四、将Anemometer文件包解压,重命名为anemometer,并移动到/var/www/html 下(apache默认路径)

[root ~]$ unzip Anemometer-master.zip
[root ~]$ mv Anemometer-master /var/www/html/anemometer

五、导入anemometer目录下的install.sql,并给该库对应的权限:

[root anemometer]$ pwd
/var/www/html/anemometer
[root anemometer]$ mysql -uroot -p123456 -S /data/mysql-5.5./mysql.sock <./mysql56-install.sql
mysql> grant all on slow_query_log.* to 'anemometer'@'%' identified by '';
Query OK, 0 rows affected (0.03 sec) mysql> grant all on slow_query_log.* to 'anemometer'@'localhost' identified by '';
Query OK, 0 rows affected (0.00 sec) mysql> grant select on *.* to 'anemometer'@'%';
Query OK, 0 rows affected (0.00 sec) mysql> grant all on slow_query_log.* to 'anemometer'@'localhost';
Query OK, 0 rows affected (0.00 sec) mysql> grant select on *.* to 'anemometer'@'localhost';
Query OK, 0 rows affected (0.00 sec)

六、修改可以视化界面的配置信息

使用Anemometer基于pt-query-digest将MySQL慢查询可视化

使用Anemometer基于pt-query-digest将MySQL慢查询可视化

修改php配置,vim /etc/php.ini添加以下内容,(如果本来就有;extension = mysqli.so,只需要把分号去掉即可,我的是yum安装的,本来没有,所以自己加)

使用Anemometer基于pt-query-digest将MySQL慢查询可视化

修改apache的配置文件,vim /etc/httpd/conf/httpd.conf

[root conf]$ cat /etc/httpd/conf/httpd.conf  |grep "ServerName"
# ServerName gives the name and port that the server uses to identify itself.
ServerName 192.168.1.128:

重启httpd,访问不了,看httpd的日志报以下错:

date_default_timezone_set(): Timezone ID 'CST' is invalid in /var/www/html/anemometer/lib/Anemometer.php on line
[Fri Nov :: ] [error] [client 192.168.1.1] PHP Warning: date_default_timezone_get(): It is not safe to rely on the system's timezone settings. You are *required* to use the date.timezone setting or the d
ate_default_timezone_set() function. In case you used any of those methods and you are still getting this warning, you most likely misspelled the timezone identifier. We selected 'Asia/Chongqing' for 'CST/8.0/no DST'
instead in /var/www/html/anemometer/lib/Anemometer.php on line

修改下/etc/php.ini

使用Anemometer基于pt-query-digest将MySQL慢查询可视化

如果重启httpd,还是访问不了,日志还是报同时区的错误,则再修改以下的:

vim /var/www/html/anemometer/lib/Anemometer.php +47  添加下内容:

使用Anemometer基于pt-query-digest将MySQL慢查询可视化

访问:http://192.168.1.128/anemometer,会提示没有global_query_review表,哈哈,别着急哈^.^

使用Anemometer基于pt-query-digest将MySQL慢查询可视化

七、将慢查询日志通过pt-query-digest分析后存入数据库中:

[root ~]$ pt-query-digest --user=anemometer --password= --socket=/data/mysql-5.5.40/mysql.sock \
> --review h=localhost,D=slow_query_log,t=global_query_review \
> --history h=localhost,D=slow_query_log,t=global_query_review_history \
> --no-report --limit=% --filter=" \$event->{Bytes} = length(\$event->{arg}) and \$event->{hostname}=\"$HOSTNAME\"" /data/mysql-5.5.40/localhost-slow.log

如果你的mysql是通过sock方式连接的话,必须加上--socket指定sock文件,执行完以上的命令,数据库里就会多出global_query_review 表和global_query_review_history表了

详细导入可以查看官方帮助文档和表属性说明:

http://www.mysqlperformanceblog.com/2012/08/28/hidden-columns-of-query_review_history/

http://code.google.com/p/maatkit/wiki/EventAttributes

回到web端查看:

使用Anemometer基于pt-query-digest将MySQL慢查询可视化

想了解更多功能,或者怎么使用,这要看大家了^.^

可以参考文章:

https://github.com/box/Anemometer

http://blog.itpub.net/26355921/viewspace-1162415/

作者:陆炫志

出处:xuanzhi的博客 http://www.cnblogs.com/xuanzhi201111

您的支持是对博主最大的鼓励,感谢您的认真阅读。本文版权归作者所有,欢迎转载,但请保留该声明。

使用Anemometer基于pt-query-digest将MySQL慢查询可视化的更多相关文章

  1. 【转载】 使用Anemometer基于pt-query-digest将MySQL慢查询可视化

    原文地址:使用Anemometer基于pt-query-digest将MySQL慢查询可视化 作者:84223932 本文主要介绍使用Anemometer基于pt-query-digest将MySQL ...

  2. 十分钟部署Anemometer作为Mysql慢查询可视化系统

    前言 采用Anemometer将Mysql慢查询日志可视化,可以更便捷的查询慢查询日志,并根据时间戳进行历史查询.如下是单机版Anemometer部署的演示,实际应用中,为安全起见,建议把anemom ...

  3. 032:基于Consul和MGR的MySQL高可用架构

    目录 一.Consul 1.Consul简介 2.准备环境 3.Consul 安装 4.Consul配置文件 5.Consul 服务检查脚本 6.Consul启动 二.MGR搭建 1.MGR配置 2. ...

  4. MySQL中查询时&quot&semi;Lost connection to MySQL server during query&quot&semi;报错的解决方案

    一.问题描述: mysql数据库查询时,遇到下面的报错信息: 二.原因分析: dw_user 表数据量比较大,直接查询速度慢,容易"卡死",导致数据库自动连接超时.... 三.解决 ...

  5. 使用Anemometer分析MySQL慢查询记录

    数据库管理员一般是用percona的toolkit工具来分析MySQL慢查询记录,但是不够直观. 下面介绍一款比较直观的工具来统计分析MySQL慢查询记录anemometer. 在使用之前需要安装pe ...

  6. Advanced Installer 11&period;9基于IIS打包札记&lpar;For MySQL&rpar;

    原文:Advanced Installer 11.9基于IIS打包札记(For MySQL) Mysql免安装前期部署 下载绿色命令行版本的mysql,将其放入到发布的程序发布包内,执行Update批 ...

  7. Django Mysql数据库-基于双下划线的跨表查询

    一.基于双下划线的跨表查询 Django 还提供了一种直观而高效的方式在查询(lookups)中表示关联关系,它能自动确认 SQL JOIN 联系.要做跨关系查询,就使用两个下划线来链接模型(mode ...

  8. mysql慢查询日志相关参数

    -- mysql慢查询日志相关参数 -- 慢查询日志时间 show variables like "long_query_time"; -- 将时间设置为2s ; -- 是否开启慢 ...

  9. mysql慢查询分析工具比较与实战

    00 前言 在进行mysql性能优化的时候,第一个想到的便是查看慢sql. 但是对于慢sql有没有什么好的工具进行分析呢? 推荐两个工具mysqldumpslow及pt-query-digest. m ...

随机推荐

  1. Selenium-java-testng插件安装eclipse

    1 进入Help----Install 2  点击 ADD 输入: TestNG http://beust.com/eclipse 点击OK 3 等一会会加载出如下图,勾选,点击Next  下一步 4 ...

  2. android 项目学习随笔二十一(IM、语音识别、机器人、统计、扫描二维码、条形码)

    语音识别:科大讯飞语音云 http://www.xfyun.cn/ 语音机器人模拟 public class TalkBean { public String text; public boolean ...

  3. &dollar;watch 和 &dollar;apply

    1.当你使用 ng-model, ng-repeat 等等来绑定一个元素的值时, AngularJS 为那个值创建了一个 $watch,只要这个值在 AngularJS 的范围内有任何改变,所有的地方 ...

  4. 【整理】c&num; 调用windows API(user32&period;dll)

    User32.dll提供了很多可供调用的接口,大致如下(转自http://blog.csdn.net/zhang399401/article/details/6978803) using System ...

  5. C&num; &period;NET 使用第三方类库DotNetZip解压&sol;压缩Zip rar文件

    DotNetZip on CodePlex: http://dotnetzip.codeplex.com/ 详细的可以看源代码……总之感觉比SharpZipLib好用.而且DotNetZip支持VB, ...

  6. HTTP有关知识

    Cookie 调用Cookie时,由于可校验Cookie的有效期,以及发送方的域,路径,协议等信息,所以正规发布的Cookie里面的内容不会因来自其他web站点和攻击者的攻击而泄露. Set-Cook ...

  7. Publisher&sol;Subscriber 订阅-发布模式

    Publisher/Subscriber 订阅-发布模式 本博后续将陆续整理这些年做的一些预研demo,及一些前沿技术的研究,与大家共研技术,共同进步. 关于发布订阅有很多种实现方式,下面主要介绍WC ...

  8. 结合jira搭建自动化测试平台

    mysql 语句查看 python manage.py sqlmigrate your_app_name 0001 代码如下 #coding=utf8 #https://jira.readthedoc ...

  9. winDBG排错小记

    去年底,公司一个上线了近一年的系统逐渐出现访问缓慢,操作超时的问题.本人使用winDBG工具对抓下来的内存映象进行了诊断,虽最后没有查出什么原因,但在过程中也学到了不少东西,现记录如下 一. “Fai ...

  10. java后台面试知识点总结

    本文主要记录在准备面试过程中遇到的一些基本知识点(持续更新) 一.Java基础知识 1.抽象类和接口的区别 接口和抽象类中都可以定义变量,但是接口中定义的必须是公共的.静态的.Final的,抽象类中的 ...