MySQL慢查询日志开启分析详解介绍

(1)配置开启

Linux:

在mysql配置文件 my.cnf 中增加如下语句:

log-slow-queries=/var/lib/mysql/slowquery.log #指定日志文件存放位置,可以为空,系统会给一个缺省的文件host_name-slow.log
long_query_time=5 #记录超过的时间,默认为10s,这里设置为查询时间超过5s的查询语句
log-queries-not-using-indexes = on # 列出没有使用索引的查询语句
#log-queries-not-using-indexes 是否记录所有没有使用索引的query,可以根据情况决定是否开启
#log-long-format 是否记录所有的查询记录,包括没有使用索引的查询

Windows:

在 my.ini 的[mysqld]添加如下语句(语句选项以及释义同上):

log-slow-queries = E:\mysql\log\mysqlslowquery.log
long_query_time = 5

(2)查看方式

Linux:

使用mysql自带命令mysqldumpslow查看

常用命令

-s ORDER what to sort by (t, at, l, al, r, ar etc), 'at’ is default
-t NUM just show the top n queries
-g PATTERN grep: only consider stmts that include this string

eg:

s,是order的顺序,说明写的不够详细,俺用下来,包括看了代码,主要有 c,t,l,r和ac,at,al,ar,分别是按照query次数,时间,lock的时间和返回的记录数来排序,前面加了a的时倒序
-t,是top n的意思,即为返回前面多少条的数据
-g,后边可以写一个正则匹配模式,大小写不敏感的

具体命令使用如下

mysqldumpslow -s c -t 20 host-slow.log

mysqldumpslow -s r -t 20 host-slow.log

上述命令可以看出访问次数最多的20个sql语句和返回记录集最多的20个sql。

mysqldumpslow -t 10 -s t -g “left join” host-slow.log这个是按照时间返回前10条里面含有左连接的sql语句。

Windows:

当你是第一次开启mysql的慢查询,会在你指定的目录下创建这个记录文件,本文就是mysqlslowquery.log,这个文件的内容大致如下(第一次开启MYSQL慢查询的情况下)

E:\web\mysql\bin\mysqld, Version: 5.4.3-beta-community-log (MySQL Community Server (GPL)). started with:
TCP Port: 3306, Named Pipe: (null)
Time Id Command Argument

可以通过如下的命令来查看慢查询的记录数:

mysql> show global status like ‘%slow%’;
+———————+——-+
| Variable_name | Value |
+———————+——-+
| Slow_launch_threads | 0 |
| Slow_queries | 0 |
+———————+——-+

生成了日志我们可以使用mysqlsla慢查询日志分析工具来进行处理具体看例子

一、mysqlsla的安装

wget http://hackmysql.com/scripts/mysqlsla-2.03.tar.gz
tar zvxf mysqlsla-2.03.tar.gz   
cd mysqlsla-2.03 
perl Makefile.PL 
make
make install
 
二、使用参数说明

1.   --log-type (-lt) type logs:
通过这个参数来制定log的类型,主要有slow, general, binary, msl, udl,分析slow log时通过制定为slow.
2.   --sort:
 制定使用什么参数来对分析结果进行排序,默认是按照t_sum来进行排序。
 t_sum按总时间排序, c_sum按总次数排序
3.   --top:
显示sql的数量,默认是10,表示取按规则排序的前多少条
4.   --statement-filter (-sf) [+-][TYPE]:
过滤sql语句的类型,比如select、update、drop. [TYPE]有SELECT, CREATE, DROP, UPDATE, INSERT,例如"+SELECT,INSERT",不出现的默认是-,即不包括。
5.   --databases db:   
要处理哪个库的日志:
 
三、统计参数说明

1. queries total: 总查询次数 
2. unique:去重后的sql数量 
3. sorted by : 输出报表的内容排序 最重大的慢sql统计信息, 包括 平均执行时间, 等待锁时间, 结果行的总数, 扫描的行总数. 
4. Count: sql的执行次数及占总的slow log数量的百分比. 
5. Time: 执行时间, 包括总时间, 平均时间, 最小, 最大时间, 时间占到总慢sql时间的百分比. 
6. 95% of Time: 去除最快和最慢的sql, 覆盖率占95%的sql的执行时间. 
7. Lock Time: 等待锁的时间. 
8.95% of Lock: 95%的慢sql等待锁时间. 
9.Rows sent: 结果行统计数量, 包括平均, 最小, 最大数量. 
10.Rows examined: 扫描的行数量. 
11.Database: 属于哪个数据库.
12.Users: 哪个用户,IP, 占到所有用户执行的sql百分比.
13. Query abstract: 抽象后的sql语句.
14. Query sample: sql语句.
 
四、使用范例

1.  统计慢查询文件为dowload_server1-slow.log的所有select的慢查询sql,并显示执行时间最长的10条sql,并写到sql_time.sql中去
mysqlsla -lt slow  -sf "+select" -top 10  dowload_server1-slow.log >test_time.log
2.  统计慢查询文件为dowload_server1-slow.log的数据库为ultraxsmutf8的所有select和update的慢查询sql,并查询次数最多的100条sql,并写到sql_num.sql中去
mysqlsla -lt slow  -sf "+select,update" -top 100 -sort c_sum -db  ultraxsmutf8 dowload_server1-slow.log >num_time.log   
 
五、FAQ

1.  错误:
Can't locate DBI.pm in @INC (@INC contains: /usr/lib/perl5/site_perl/5.8.8/i386-linux-thread-…….
解决办法: perl -MCPAN -e 'install DBI' 或者cpan DBI
     2、错误:
Use of uninitialized value in numeric comparison (<=>) at /usr/bin/mysqlsla line 2962.
 
解决办法:当采用-sort t_su就会出现这个错误,默认就是采用时间排序,因此可以去掉.

删除慢查询日志

直接通过命令 rm -f 删除了慢查询日志

三、出现问题

慢查询日志没有自动生成,(如果有备份,再次拷贝回来也是不好使的)

四、解决方法

管理员身份登录MySQL 执行命令 flush logs;
如果执行后,提示执行成功,而实际上慢查询日志还是没有生成,则执行以下命令(先关闭慢查询,再开启)
SET GLOBAL log_slow_queries = off;(关闭慢查询)
SET GLOBAL log_slow_queries = ON;(重开启慢查询)
问题解决,OK!

五、建议

如果遇到慢查询日志文件过大,需要回收空间加以利用,或者其他原因需要删除慢查询日志文件,建议不要直接 rm 掉慢查询日志文件,可以置空日志文件,
如:>mysql-slow.log

时间: 2025-01-29 13:01:57

MySQL慢查询日志开启分析详解介绍的相关文章

MySQL慢查询日志配置方法详解

查看 MySQL 服务器的慢查询状态是否开启:     1 show variables like '%slow%';   slow_launch_time,表示超过2秒定义为慢查询 log_slow_queries 和 slow_query_log,表示慢查询已经开启 slow_query_log_file,表示慢查询日志的文件的位置   在 mysql 的配置文件 my.cnf 或 my.ini 的 [mysqld]下加入慢查询的配置语句的设置即可开启慢查询状态:   1 #定义超过指定时间

对MySQL慢查询日志进行分析的基本教程_Mysql

0.首先查看当前是否开启慢查询: (1)快速办法,运行sql语句 show VARIABLES like "%slow%" (2)直接去my.conf中查看. my.conf中的配置(放在[mysqld]下的下方加入) [mysqld] log-slow-queries = /usr/local/mysql/var/slowquery.log long_query_time = 1 #单位是秒 log-queries-not-using-indexes 使用sql语句来修改:不能按照m

mysql 慢查询日志开启与使用详解

MySQL慢日志往往是大家定位SQL性能问题.通过慢日志分析可以调整索引使用.这是使用最多的一个功能. 目前MySQL也支持毫秒级别以下的慢日志记录,这个功能其实有很多用处,这里大概给大家讲解一下.该功能开启参数:long_query_time 查看慢查询是否开启:  代码如下 复制代码 mysql> show variables like '%slow%'; +---------------------+-------------------------+ | Variable_name   

Mysql慢查询使用与参数详解

慢查询为系统中查询时间超过long_query_time的值,分析慢查询是优化SQL的基础,默认清下Mysql慢查询为关闭状态,可以通过 show variables where Variable_name = 'log_slow_queries'; 来查看是否开启,如果为OFF则需要修改mysql配置文件,在mysqld下面增加以下参数 #慢查询日志地址,需要mysql运行帐号对该目录有写权限 log-slow-queries="/log/slow.log" #当query语句大于2

MySql慢查询日志——开启/查看/删除

1,开启慢查询日志 修改mysql.ini文件,加入如下配置: [mysqld] log-slow-queries=H:\mysql_log\slow_query.log long-query-time=3 set global slow_query_log=ON; set global slow_launch_time=5; show variables like "%slow%"; 设置查询日志的存储位置,慢查询时间. show variables like '%slow%'; /

MySQL触发器的用途和用法详解介绍

触发器是一种特殊的存储过程,它在插入,删除或修改特定表中的数据时触发执行,它比数据库本身标准的功能有更精细和更复杂的数据控制能力.触发器的作用: 1. 安全性.可以基于数据库的值使用户具有操作数据库的某种权利: 可以基于时间限制用户的操作,例如不允许下班后和节假日修改数据库数据: 可以基于数据库中的数据限制用户的操作,例如不允许股票的价格的升幅一次超过10%. 2. 审计.可以跟踪用户对数据库的操作: 审计用户操作数据库的语句: 把用户对数据库的更新写入审计表. 3. 实现复杂的数据完整性规则:

Monolog PHP日志类库使用详解介绍

Monolog遵循PSR3的接口规范,可以很轻易的替换成其他遵循同一规范的日志类库.Monolog具有良好的扩展性,通过Handler.Formatter和Processor这几个接口,可以对Monolog类库进行各种扩展和自定义. 基本用法 可以通过github或者composer安装Monolog,以下是使用composer安装最新版本: composer require monolog/monolog 如果您还不了解composer是什么? 请点这里. 要求PHP版本为5.3以上. <?p

mysql SELECT查询的速度优化详解

总的来说,要想使一个较慢速select ... where更快,应首先检查是否能增加一个索引.不同表之间的引用通常通过索引来完成.你可以使用explain语句来确定select语句使用哪些索引.参见7.4.5节,"mysql教程如何使用索引"和7.2.1节,"explain语法(获取关于select的信息)". 下面是一些加速对myisam表的查询的一般建议: ·         为了帮助mysql更好地优化查询,在一个装载数据后的表上运行analyze table

MySQL 5.7的JSON数据类型详解介绍

在MySQL 5.7.8中,MySQL支持原生JSON 数据类型,使有效的数据访问在JSON(JavaScript对象符号)的文件.该 JSON数据类型提供了这些优点存储JSON格式的字符串,字符串中的列: 自动验证存储在JSON文件 JSON列.无效的文件产生错误. 优化的存储格式.存储在JSON文件 JSON列转换为内部格式,允许以文档元素快速读取权限.当服务器后来必须读取存储在此的二进制格式的JSON值,该值不必从一个文本表示解析.二进制格式的结构,以使服务器查找子对象或嵌套值直接通过按键