mysql的慢查询相关问题

装载于:http://blog.csdn.net/moqiang02/article/details/34116993 **如何在windows下是用mysqldumpslow命令**

1. 再一次点击mysql安装文件(默认是没安装mysqldumpslow这些脚本的),如图:

 

点击next如下图

 

点击Developer Components 旁边的选择this feature , and all subfeatures will be 

Install(安装所有子项)… 之后一步一步继续安装下去,完成之后,你会看到你的mysql安装目录下多了一个scripts包,包中就有mysqldumpslow脚本 如何执行这个脚本呢?

这就需要安装下面的activeperl了


2. 安装 ActivePerl:从http://www.activestate.com/activeperl下载最新版ActivePerl-5.12.1.1201-MSWin32-x86-292674.zip 解压后点击Installer.bat文件 一步一步安装完,配置环境变量(右击我的电脑–属性–高级–环境变量–在系统变量部分–双击path–在最后添加你perl的安装路径。例如;C:\Perl\bin)验证安装完整,开始—cmd—perl -v 如果有版本信息提示,说明安装成功。


3. 运行狗狗脚本,开始—cmd—cd 桌面–perl gougou.pl (这里假设你的脚本是放在桌面上的,文件名为gougou.pl,请按实际情况修改)

 

注:如何开启mysql slow log记录日记网上一查一大把 本人就不赘述了(百度一下mysql slow query log)

windows下使用MYSQL的mysqldumpslow进行慢日志分析

1、首先安装好perl环境。

2、在dos环境中,切换到perl目录中,例如我的目录是

dos 命令 cd c:\Perl\bin

3、在此目录输入perl mysqldumpslow的路径\mysqldumpslow.pl+mysqldumpslow命令 +slow.log的路径+输出的地方
例如:我的mysqldumpslow目录为

slow.log的目录为C:\Perl\bin\slow.log
输出的文件为time .txt,目录为E:\


mysqldumpslow的命令参数列举如下:

–help    输出帮助信息

-v           输出详细信息 
-d          调试
-s          按照什么排序,默认是’at’,显示顺序为倒序
              al: 平均锁表时间

ar: 平均结果行数
                at: 平均查询时间
                 c: 次数
                 l: 锁表时间
                 r: 总结果行数
                 t: 总查询时间  
 -r          正序排序,即从小到大排序

-t NUM       限制显示的条数

-a           显示出数字和字符串,默认数字为 N 字符串为 ‘S’
-g PATTERN   过滤字符串,后接正则表达式,如’10$’ 以10为结尾的条件

例子:

/usr/local/mysql/bin/mysqldumpslow -s t -a -t 3   slow.txt

根据总查询时间排序,只列出前3条

/usr/local/mysql/bin/mysqldumpslow -r -s c -a -t 3 -g ‘hello’   slow.txt

搜索包括关键字 hello的结果,并按照次数正序排序前3条


快速开启MySQL慢日志查询的方法

MySQL慢日志查询对于很多刚接触MySQL数据的新人来说比较陌生,下面就为您介绍MySQL慢日志查询的用法和好处,供您参考。 
mysql有一个功能就是可以log下来运行的比较慢的sql语句,默认是没有这个log的。
 
Windows下开启MySQL慢查询
打开 my.ini ,找到 [mysqld] 在其下面添加 
long_query_time = 2
log-slow-queries = D:/mysql/logs/slow.log #设置把日志写在那里,可以为空, 系统会给一个缺省的文件
#log-slow-queries = /var/youpath/slow.log linux下host_name-slow.log
log-queries-not-using-indexes

Linux下启用MySQL慢查询
MySQL在Linux系统中的配置文件一般是是my.cnf找到[mysqld]下面加上
log-slow-queries=/data/mysqldata/slowquery.log
long_query_time=2
log-queries-not-using-indexes

 
long_query_time 是指执行超过多长时间(单位是秒)的sql会被记录下来,这里设置的是2秒。
log-slow-queries 设置日志所在位置,可以为空,系统会给一个缺省的文件host_name-slow.log,生成的日志就在mysql的data目录下
log-queries-not-using-indexes 就是字面意思,记录下没有使用索引的query。
 
以下是mysqldumpslow常用参数说明,详细的可应用mysqldumpslow -help查询。 
-s,是表示按照何种方式排序,c、t、l、r分别是按照记录次数、时间、查询时间、返回的记录数来排序(从大到小),ac、at、al、ar表示相应的倒叙。 
-t,是top n的意思,即为返回前面多少条数据。
-g,后边可以写一个正则匹配模式,大小写不敏感。
 
接下来就是用mysql自带的慢查询工具mysqldumpslow分析了(mysql的bin目录下),我这里的日志文件名字是host-slow.log。
 
列出记录次数最多的10个sql语句 
mysqldumpslow -s c -t 10 host-slow.log
 
列出返回记录集最多的10个sql语句 
mysqldumpslow -s r -t 10 host-slow.log
 
按照时间返回前10条里面含有左连接的sql语句 
mysqldumpslow -s t -t 10 -g “left join” host-slow.log
 
使用mysqldumpslow命令可以非常明确的得到各种我们需要的查询语句,对MySQL查询语句的监控、分析、优化起到非常大的帮助。
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值