mysql 高级(基础六 慢查询日志 mysqldumpslow )

本文详细介绍了Mysql的慢查询日志功能,包括如何设置慢查询阈值,开启和配置慢查询日志,以及如何通过日志分析工具mysqldumpslow进行SQL性能优化。了解这些内容对于数据库调优至关重要。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Mysql 的慢查询日志是Mysql提供的一种日志记录,它用来记录在mysql中响应时间超过阈值的语句,具体指运行时间超过long_query_time 值的slq,则会被记录到慢查询日志中。

long_query_time 默认是10 ,意思是运行10秒以上的语句。

由他来查看哪些sql超出了我们的最大忍耐时间值,比如一条sql执行超过5秒,我们就算慢sql,希望能收集超过5秒的sql,结合之前explain进行全面分析。

默认情况下,mysql数据库没有开启慢查询日志,需要我们手动来设置这个参数。

当然,如果不是调优需要的话,一般不建议启动该参数,因为开启慢查询日志会或多或少带来一定的性能影响。慢查询日志支持将日志记录写入文件。

日志存储文件

show variables like '%slow_query_log%';

这里写图片描述
开启慢日志:重启会失效

set global slow_query_log=1;

如果要永久生效,就必须修改配置文件my.cnf(其它系统变量也是如此)
修改my.cnf文件,[mysqld]下增加或修改参数
将如下两行配置进my.cnf文件

slow_query_log =1
 slow_query_log_file=/var/run/mysqld/mysqld-slow.log
 SHOW VARIABLES LIKE 'long_query_time%';

默认10秒
这里写图片描述
10秒?等不起,设置阈值3秒钟的就是慢

set global long_query_time=3;

需要新开一个会话,才能看到修改值

设置一条慢查询:
查看慢sql条数:

select sleep(4);
show global status like '%Slow_queries%';

这里写图片描述
慢日志 库 sql抓取 :查看慢查询日志
这里写图片描述

mysqldumpslow :日志抓取命令
这里写图片描述
得到返回记录集最多的10个sql
mysqldumpslow -s r -t 10 /var/run/mysqld/mysqld-slow.log
得到访问次数最多的10个sql
mysqldumpslow -s c -t 10 /var/run/mysqld/mysqld-slow.log
得到按照时间排序的前10条里面含有左连接的查询语句
mysqldumpslow -s t -t 10 -g “left join” /var/run/mysqld/mysqld-slow.log
另外建议在使用这些命令时结合|和more使用,否则有可能出现爆屏情况
mysqldumpslow -s r -t 10 /var/run/mysqld/mysqld-slow.log | more

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值