欢迎重视MySQL专栏MySQL历险记
强烈建议收藏本导航文【MySQL历险记】MySQL的中心特性汇总

前言

在项目里边,多多少少都隐藏着一些履行比较慢的SQL, 不同的开发测验人员在平常运用的过程中多多少少都能够遇到,但是无法立马有时刻去排查解决。那么如果有一个文件能够将这些运用过程中比较慢的SQL记载下来,定时去剖析排查,那该多美好啊。这种状况MySQL也替咱们想到了,它供给了SQL慢查询的日志,本文就分享下怎样运用吧。

什么是慢查询日志?

MySQL的慢询日志,供给了记载在MySQL中响应时刻超过指定阈值语句的功用,比如设定阈值为3秒,那么任何SQL履行超过3秒都会被记载下来。

咱们凭借慢查询日志功用能够发现哪些那些履行时刻特别长的询,并且有针对性地进行优化,从而进步系统的整体功率。

怎样敞开慢查询日志?

默认状况下,MySQL数据库没有敞开慢查询日志,因为多多少少会带来一定性能的影响。咱们能够在开发测验环境、或者出产环境做调优的时候敞开,那怎样检查是否敞开了呢?

  1. 检查慢SQL是否敞开

履行下面指令检查是否敞开慢SQL

show variables like '%slow_query_log';

你的哪些SQL慢?看看MySQL慢查询日志吧

  • OFF: 未敞开
  • ON: 敞开
  1. 怎样敞开慢查询

履行下面的指令敞开慢查询日志

 set global slow_query_log='ON';

你的哪些SQL慢?看看MySQL慢查询日志吧

  1. 修正慢查询阈值

前面介绍了SQL履行到达了拟定的时刻阈值跋文录到慢查询日志中,那么怎样设置呢?

set global long_query_time = N;
set long_query_time = N
  • 设置global的方法对当前sessionlong_query_time失效。对新衔接的客户端有用。所以能够同时履行下述语句
  • N标明设置的阈值,单位为秒

你的哪些SQL慢?看看MySQL慢查询日志吧

  • 这儿的show global variables like '%long_query_time%';能够检查阈值大小
  1. 怎样设置永久收效

前面是经过指令行的方法设置,如果MySQL重启,那么装备就会重置。咱们能够经过修正MySQL的装备my.cfg或者my.ini永久收效。

[mysqld]
slow_query_log=ON  # 敞开慢查询日志开关
slow_query_log_file=/var/lib/mysql/alvin-slow.log  # 慢查询日志的目录和文件名信息
long_query_time=3  # 设置慢查询的阈值为3秒,超出此设定值的SQL即被记载到慢查询日志
log_output=FILE

慢查询日志在哪里呢?

前面解说了怎样敞开MySQL的慢查询日志,那么它把日志记载在哪里了呢?

  1. 检查慢查询日志方位

经过show variables like '%slow_query_log_file%';指令能够检查慢SQL文件方位,如下图所示:

你的哪些SQL慢?看看MySQL慢查询日志吧

  1. 修正慢查询日志方位

也很简单,履行下面的指令即可:

set global slow_query_log_file = '/usr/local/mysql/data/alvin-slow-slow.log';

怎样检查慢SQL内容?

现在咱们已经知道慢查询日志在哪里了,那么怎样检查里边的内容呢?咱们这儿用一个比如演示下吧。

  1. 履行一个查询的SQL

你的哪些SQL慢?看看MySQL慢查询日志吧

  • 履行花了1秒多,超过了前面设置的阈值1s
  1. 检查慢查询数目

履行下面指令查询当前系统中有多少条慢查询记载

SHOW GLOBAL STATUS LIKE '%Slow_queries%';

你的哪些SQL慢?看看MySQL慢查询日志吧

  • value=1, 标明刚刚的日志被记载了。
  1. 检查日志内容

经过cat指令检查文件内容,能够看到对应的慢SQL。

你的哪些SQL慢?看看MySQL慢查询日志吧

慢查询日志剖析东西mysqldumpslow

果要手工剖析日志,查找、剖析SQL,显然是个体力活,MySQL供给了日志剖析东西 mysqldumpslow

mysqldumpslow 指令的具体参数如下:

  • -a: 不将数字抽象成N,字符串抽象成S
  • -s: 是标明依照何种方法排序:
    • c: 拜访次数
    • l: 锁定时刻
    • r: 回来记载
    • t: 查询时刻
    • al:平均锁定时刻
    • ar:平均回来记载数
    • at:平均查询时刻 (默认方法)
    • ac:平均查询次数
  • -t: 即为回来前面多少条的数据;
  • -g: 后边调配一个正则匹配模式,大小写不敏感的;

可mysqldumpslow方位mysql的bin目录下,以经过履行 mysqldumpslow –help指令检查运用。

举例: 咱们想要依照查询时刻排序,检查前五条 SQL 语句,这样写即可:

mysqldumpslow -s t -t 5 /usr/local/mysql/data/alvin-slow-slow.log

你的哪些SQL慢?看看MySQL慢查询日志吧

常见的用法:

#得到回来记载集最多的10个SQL
mysqldumpslow -s r -t 10 /usr/local/mysql/data/alvin-slow-slow.log
#得到拜访次数最多的10个SQL
mysqldumpslow -s c -t 10 /usr/local/mysql/data/alvin-slow-slow.log
#得到依照时刻排序的前10条里边含有左衔接的查询语句
mysqldumpslow -s t -t 10 -g "left join" /usr/local/mysql/data/alvin-slow-slow.log
#另外建议在运用这些指令时结合 | 和more 运用 ,否则有或许呈现爆屏状况
mysqldumpslow -s r -t 10 /usr/local/mysql/data/alvin-slow-slow.log | more

怎样删去慢SQL日志?

现在慢查询日志很多了啊,为了不互相混杂,我要删去一些慢SQL日志,怎样删去呢?

  1. 手动删去慢查询日志文件即可, 也便是rm指令。
  2. 运用指令mysqladmin flush-logs 重置慢sql日志内容,完好指令如下 :
mysqladmin -uroot -p flush-logs slow

总结

本文解说了慢SQL日志该怎样翻开以及运用,是非常重要有用的排查手法,最跋文得在排查完毕以后,要关闭慢SQL日志,不然或许影响性能哦。

如果本文对你有帮助的话,请留下一个赞吧

本文正在参与「金石计划 . 瓜分6万现金大奖」