这是我参与更文挑战的第5天,活动详情查看: 活动链接
1、MySQL慢查询日志是什么
(1)MySQL的慢查询日志是MySQL提供的一种日志记录,它用来记录MySQL中查询时间超过(大于)设置阈值(long_query_time)的语句,记录到慢查询日志中。
(2)long_query_time的默认值是10。
2、如何开启MySQL慢查询日志
默认情况下,MySQL没有开启慢查询日志。需要手动打开,如果不是调优需要的话,不建议开启,因为开启会带来一定的性能影响,慢查询日志支持将日志记录写入文件。
(1)开启设置
1 | sql复制代码-- 查看慢查询日志是否开启 |
1 | sql复制代码-- 开启慢查询日志,只对当前数据库生效,并且重启数据库后失效 |
1 | sql复制代码-- 查看慢查询日志的阈值,默认10s |
1 | sql复制代码-- 设置阈值 |
(2)如果需要永久生效则修改配置文件my.cnf
1 | ini复制代码[mysqld] |
(3)运行慢查询sql,查看慢查询日志
1 | sql复制代码select sleep(4); |
(4)查询当前系统有多少条慢查询记录
1 | sql复制代码show global status like '%Slow_queries%'; |
3、日志分析工具mysqldumpslow
慢查询日志多了,不利于我们进行分析。mysqldumpslow能将相同的慢SQL归类,并统计出相同的SQL执行的次数,每次执行耗时多久、总耗时,每次返回的行数、总行数,以及客户端连接信息等。
通过 –help命令,就能知道如何使用Mysqlsumpslow
- -s 表示按何种方式排序。
- c 访问次数。
- l 锁定时间。
- r 返回记录。
- t 查询时间。
- al 平均锁定时间。
- ar 平均返回记录数。
- at 平均查询时间。
- -t 返回前面多少条数据。
- -g 后面搭配一个正则匹配模式,大小写不敏感。
1 | shell复制代码# 得到返回记录集最多的10 个SQL |
本文转载自: 掘金