https://www.cnblogs.com/kerrycode/p/5593204.html

慢查询日志概念

MySQL的慢查询日志是MySQL提供的一种日志记录,它用来记录在MySQL中响应时间超过阀值的语句,具体指运行时间超过long_query_time值的SQL,则会被记录到慢查询日志中。long_query_time的默认值为10,意思是运行10S以上的语句。默认情况下,Mysql数据库并不启动慢查询日志,需要我们手动来设置这个参数,当然,如果不是调优需要的话,一般不建议启动该参数,因为开启慢查询日志会或多或少带来一定的性能影响。慢查询日志支持将日志记录写入文件,也支持将日志记录写入数据库表。

官方文档,关于慢查询的日志介绍如下(部分资料,具体参考官方相关链接):

The slow query log consists of SQL statements that took more than long_query_time seconds to execute and required at least min_examined_row_limit rows to be examined. The minimum and default values of long_query_time are 0 and 10, respectively. The value can be specified to a resolution of microseconds. For logging to a file, times are written including the microseconds part. For logging to tables, only integer times are written; the microseconds part is ignored.

By default, administrative statements are not logged, nor are queries that do not use indexes for lookups. This behavior can be changed usinglog_slow_admin_statements and log_queries_not_using_indexes, as described later.

慢查询日志相关参数

MySQL 慢查询的相关参数解释:

slow_query_log    :是否开启慢查询日志,1表示开启,0表示关闭。

log-slow-queries  :旧版(5.6以下版本)MySQL数据库慢查询日志存储路径。可以不设置该参数,系统则会默认给一个缺省的文件host_name-slow.log

slow-query-log-file:新版(5.6及以上版本)MySQL数据库慢查询日志存储路径。可以不设置该参数,系统则会默认给一个缺省的文件host_name-slow.log

long_query_time :慢查询阈值,当查询时间多于设定的阈值时,记录日志。

log_queries_not_using_indexes:未使用索引的查询也被记录到慢查询日志中(可选项)。

log_output:日志存储方式。log_output='FILE'表示将日志存入文件,默认值是'FILE'。log_output='TABLE'表示将日志存入数据库,这样日志信息就会被写入到mysql.slow_log表中。MySQL数据库支持同时两种日志存储方式,配置的时候以逗号隔开即可,如:log_output='FILE,TABLE'。日志记录到系统的专用日志表中,要比记录到文件耗费更多的系统资源,因此对于需要启用慢查询日志,又需要能够获得更高的系统性能,那么建议优先记录到文件。

慢查询日志配置

默认情况下slow_query_log的值为OFF,表示慢查询日志是禁用的,可以通过设置slow_query_log的值来开启,如下所示:

like '%slow_query_log%';
| Variable_name       | Value                                         |
| slow_query_log      | OFF                                           |
+---------------------+-----------------------------------------------+
in set (0.00 sec)
mysql> set global slow_query_log=1;
 
like '%slow_query_log%';
| Variable_name       | Value                                         |
| slow_query_log      | ON                                            |
+---------------------+-----------------------------------------------+
in set (0.00 sec)
mysql> 

使用set global slow_query_log=1开启了慢查询日志只对当前数据库生效,如果MySQL重启后则会失效。如果要永久生效,就必须修改配置文件my.cnf(其它系统变量也是如此)。例如如下所示:

like 'slow_query%';
| Variable_name       | Value                                         |
| slow_query_log      | OFF                                           |
+---------------------+-----------------------------------------------+
in set (0.01 sec)
mysql> 

修改my.cnf文件,增加或修改参数slow_query_log 和slow_query_log_file后,然后重启MySQL服务器,如下所示

slow_query_log =1

slow_query_log_file=/tmp/mysql_slow.log

like 'slow_query%';
| Variable_name       | Value               |
| slow_query_log      | ON                  |
+---------------------+---------------------+
in set (0.00 sec)
mysql> 

关于慢查询的参数slow_query_log_file ,它指定慢查询日志文件的存放路径,系统默认会给一个缺省的文件host_name-slow.log(如果没有指定参数slow_query_log_file的话)

like 'slow_query_log_file';
| Variable_name       | Value                                         |
| slow_query_log_file | /home/WDPM/MysqlData/mysql/DB-Server-slow.log |
1 row in set (0.00 sec)

那么开启了慢查询日志后,什么样的SQL才会记录到慢查询日志里面呢? 这个是由参数long_query_time控制,默认情况下long_query_time的值为10秒,可以使用命令修改,也可以在my.cnf参数里面修改。关于运行时间正好等于long_query_time的情况,并不会被记录下来。也就是说,在mysql源码里是判断大于long_query_time,而非大于等于。从MySQL 5.1开始,long_query_time开始以微秒记录SQL语句运行时间,之前仅用秒为单位记录。如果记录到表里面,只会记录整数部分,不会记录微秒部分。

like 'long_query_time%';
| Variable_name   | Value     |
| long_query_time | 10.000000 |
1 row in set (0.00 sec)
mysql> set global long_query_time=4;
 
like 'long_query_time';
| Variable_name   | Value     |
| long_query_time | 10.000000 |
1 row in set (0.00 sec)

如上所示,我修改了变量long_query_time,但是查询变量long_query_time的值还是10,难道没有修改到呢?注意:使用命令 set global long_query_time=4修改后,需要重新连接或新开一个会话才能看到修改值。你用show variables like 'long_query_time'查看是当前会话的变量值,你也可以不用重新连接会话,而是用show global variables like 'long_query_time'; 如下所示:

在MySQL里面执行下面SQL语句,然后我们去检查对应的慢查询日志,就会发现类似下面这样的信息。

select sleep(3);
| sleep(3) |
|        0 |
1 row in set (3.00 sec)
[root@DB-Server ~]# more /tmp/mysql_slow.log
Tcp port: 0  Unix socket: (null)
/usr/sbin/mysqld, Version: 5.6.20-enterprise-commercial-advanced-log (MySQL Enterprise Server - Advanced Edition (Commercial)). started with:
null)
# Time: 160616 17:24:35
# Query_time: 3.002615  Lock_time: 0.000000 Rows_sent: 1  Rows_examined: 0
timestamp=1466069075;
select sleep(3);

log_output 参数是指定日志的存储方式。log_output='FILE'表示将日志存入文件,默认值是'FILE'。log_output='TABLE'表示将日志存入数据库,这样日志信息就会被写入到mysql.slow_log表中。MySQL数据库支持同时两种日志存储方式,配置的时候以逗号隔开即可,如:log_output='FILE,TABLE'。日志记录到系统的专用日志表中,要比记录到文件耗费更多的系统资源,因此对于需要启用慢查询日志,又需要能够获得更高的系统性能,那么建议优先记录到文件。

like '%log_output%';
| Variable_name | Value |
| log_output    | FILE  |
1 row in set (0.00 sec)
mysql> set global log_output='TABLE';
 
like '%log_output%';
| Variable_name | Value |
| log_output    | TABLE |
1 row in set (0.00 sec)
mysql> select sleep(5) ;
| sleep(5) |
|        0 |
1 row in set (5.00 sec)
mysql> 
mysql> select * from mysql.slow_log;
| start_time          | user_host                 | query_time | lock_time | rows_sent | rows_examined | db | last_insert_id | insert_id | server_id | sql_text        | thread_id |
| 2016-06-16 17:37:53 | root[root] @ localhost [] | 00:00:03   | 00:00:00  |         1 |             0 |    |              0 |         0 |         1 | select sleep(3) |         5 |
select sleep(5) |         2 |
2 rows in set (0.00 sec)
mysql> 

系统变量log-queries-not-using-indexes:未使用索引的查询也被记录到慢查询日志中(可选项)。如果调优的话,建议开启这个选项。另外,开启了这个参数,其实使用full index scan的sql也会被记录到慢查询日志。

This option does not necessarily mean that no index is used. For example, a query that uses a full index scan uses an index but would be logged because the index would not limit the number of rows.

like 'log_queries_not_using_indexes';
| Variable_name                 | Value |
| log_queries_not_using_indexes | OFF   |
1 row in set (0.00 sec)
mysql> set global log_queries_not_using_indexes=1;
 
like 'log_queries_not_using_indexes';
| Variable_name                 | Value |
| log_queries_not_using_indexes | ON    |
1 row in set (0.00 sec)
mysql> 

系统变量log_slow_admin_statements表示是否将慢管理语句例如ANALYZE TABLE和ALTER TABLE等记入慢查询日志

like 'log_slow_admin_statements';
| Variable_name             | Value |
| log_slow_admin_statements | OFF   |
1 row in set (0.00 sec)
mysql> 

系统变量log_slow_slave_statements 表示

By default, a replication slave does not write replicated queries to the slow query log. To change this, use thelog_slow_slave_statements system variable.

When the slow query log is enabled, this variable enables logging for queries that have taken more than long_query_time seconds to execute on the slave. This variable was added in MySQL 5.7.1. Setting this variable has no immediate effect. The state of the variable applies on all subsequent START SLAVE statements.

参数--log-short-format

The server writes less information to the slow query log if you use the --log-short-format option.

  • Command-Line Format --log-short-format
    Permitted Values Type boolean
    Default FALSE

另外,如果你想查询有多少条慢查询记录,可以使用系统变量。

global status like '%Slow_queries%';
| Variable_name | Value |
| Slow_queries  | 2104  |
1 row in set (0.00 sec)
mysql> 

日志分析工具mysqldumpslow

在生产环境中,如果要手工分析日志,查找、分析SQL,显然是个体力活,MySQL提供了日志分析工具mysqldumpslow

查看mysqldumpslow的帮助信息:

Usage: mysqldumpslow [ OPTS... ] [ LOGS... ]
Parse and summarize the MySQL slow query log. Options are
  --verbose    verbose
  --help       write this text to standard output
  -v           verbose
  -s ORDER     what to sort by (al, at, ar, c, l, r, t), 'at' is default
                ar: average rows sent
                 c: count
                 r: rows sent
  -r           reverse the sort order (largest last instead of first)
  -a           don't abstract all numbers to N and strings to 'S'
  -g PATTERN   grep: only consider stmts that include this string
               default is '*', i.e. match all
  -l           don't subtract lock time from total time

-s, 是表示按照何种方式排序,

c: 访问计数

l: 锁定时间

r: 返回记录

t: 查询时间

al:平均锁定时间

ar:平均返回记录数

at:平均查询时间

-t, 是top n的意思,即为返回前面多少条的数据;

-g, 后边可以写一个正则匹配模式,大小写不敏感的;

比如

得到返回记录集最多的10个SQL。

mysqldumpslow -s r -t 10 /database/mysql/mysql06_slow.log

得到访问次数最多的10个SQL

mysqldumpslow -s c -t 10 /database/mysql/mysql06_slow.log

得到按照时间排序的前10条里面含有左连接的查询语句。

mysqldumpslow -s t -t 10 -g “left join” /database/mysql/mysql06_slow.log

另外建议在使用这些命令时结合 | 和more 使用 ,否则有可能出现刷屏的情况。

mysqldumpslow -s r -t 20 /mysqldata/mysql/mysql06-slow.log | more

参考资料:

https://dev.mysql.com/doc/refman/5.7/en/slow-query-log.html

https://dev.mysql.com/doc/refman/5.7/en/server-system-variables.html#sysvar_long_query_time

转载于:https://www.cnblogs.com/davidwang456/articles/9497584.html

MySQL慢查询日志总结相关推荐

  1. MySQL 慢查询日志分析及可视化结果

    MySQL 慢查询日志分析及可视化结果 MySQL 慢查询日志分析 pt-query-digest分析慢查询日志 pt-query-digest --report slow.log 报告最近半个小时的 ...

  2. mysql慢查询日志平时开启吗_MySQL开启慢查询日志功能的方法

    mysql慢查询日志对于跟踪有问题的查询非常有用,可以分析出当前程序里是否有很耗费资源的sql语句,这是一个有用的日志.它对于性能的影响不大(假设所有查询都很快),并且强调了那些最需要注意的查询(丢失 ...

  3. MySQL慢查询日志的配置与使用_MySQL 慢查询日志的开启与配置

    简介 MySQL 慢查询日志是排查问题 SQL 语句,以及检查当前 MySQL 性能的一个重要功能. 查看是否开启慢查询功能: mysql> show variables like 'slow_ ...

  4. 6、MySQL慢查询日志(Slow Query Log)

    慢查询日志用来记录在 MySQL 中执行时间超过指定时间的查询语句.通过慢查询日志,可以查找出哪些查询语句的执行效率低,以便进行优化. 通俗的说,MySQL 慢查询日志是排查问题的 SQL 语句,以及 ...

  5. mysql慢查询日志 Mysql慢查询

    mysql慢查询日志对于跟踪有问题的查询非常有用,可以分析出当前程序里有很耗费资源的sql语句,那如何打开mysql的慢查询日志记录呢?    其实打开mysql的慢查询日志很简单,只需要在mysql ...

  6. mysql 慢查询日志的作用_MySQL慢查询日志的作用和开启

    前言 MySQL的慢查询日志是MySQL提供的一种日志记录,它用来记录在MySQL中响应时间超过阀值的语句,具体指运行时间超过long_query_time值的SQL,则会被记录到慢查询日志中.lon ...

  7. ELK logstash 处理MySQL慢查询日志

    介绍 在生产环境下,logstash 经常会遇到处理多种格式的日志,不同的日志格式,解析方法不同.下面来说说logstash处理多行日志的例子,对MySQL慢查询日志进行分析,这个经常遇到过,网络上疑 ...

  8. 开启MYSQL慢查询日志

    1.修改my.cnf或my.ini 1).linux----------------------------------- /etc/my.cnf 文件 [mysqld]long_query_time ...

  9. 读懂mysql慢查询日志

    我们来看一下如何去读懂这些慢查询日志. 在跟踪慢查询日志之前,首先你得保证最少发生过一次慢查询.如果你没有可以自己制造一个: root@server# mysql -e 'SELECT SLEEP(8 ...

  10. MySQL 慢查询日志 使用方法浅析 日志定位与优化技巧

    目录 前言 1.如何开启使用慢查询日志? 1.1 开启慢查询日志 1.2 设置慢查询阈值 1.3 确定慢查询日志的文件名和路径 1.3.1 查询MySQL数据目录 1.3.2 查询慢查询日志文件名 1 ...

最新文章

  1. 零基础学习UI设计有哪些简单有效的方法
  2. php微信级联菜单,php微信公众号开发之二级菜单
  3. 行为型模式之十一:备忘录模式
  4. delete指针之后应该赋值NULL
  5. XHTML 学前概述
  6. 为什么中国程序员水平一直上不了层次?无非是这些原因!
  7. springmvc和mybatis面试题
  8. 非常不错的Nodejs工具:http-console
  9. 求生欲很强!魅族16s Pro正式发布,2699元起
  10. 字符集及其存储方式(解决乱码问题)
  11. exescope使用
  12. LFW数据集—人脸对齐
  13. 【2020年高被引学者】 韩家炜 伊利诺伊大学香槟分校
  14. MATLAB获取Excel指定行列数据及删除指定行数据
  15. 1143 Lowest Common Ancestor (30分) 附测试点分析
  16. java图片去掉水印
  17. U盘名从E:/变成F:/,怎么修改回来
  18. UESTC 1593 老司机破阵 优先队列+双端链表
  19. SAPGUI 里 F1 功能键的用法专题讲解试读版
  20. SM4加密算法原理以及C语言实现

热门文章

  1. 苹果11怎么关掉横屏_苹果手机这些常规操作你可能不会!教你省电又省心?
  2. php下dat函数e,PHP 常用函数记录 一
  3. python 回归去掉共线性_以IPL数据集为例的线性回归技术概述
  4. 文本编辑器实现关于对话框的功能
  5. java 同步方式 lock_java的两种同步方式, Synchronized与ReentrantLock的区别
  6. xa 全局锁_fescar锁设计和隔离级别的理解
  7. 宏碁电脑开启虚拟化技术_开启windows电脑的cpu虚拟化(VT)图文操作步骤
  8. jdbc封装工具类代码_JDBC的使用-JDBC(3)
  9. 增加fast cgi进程数 php7,使用 FastCGI 模式运行 PHP7 教程
  10. java 之在校期间最后一次实训记录