首页常见问题正文

MySQL怎样开启慢查询日志?

更新时间:2023-08-07 来源:黑马程序员 浏览量:

IT培训班

慢查询日志记录了所有执行时间超过指定参数(long_query_time,单位:秒,默认10秒)的所有SQL语句的日志。MySQL的慢查询日志默认没有开启,我们可以查看一下系统变量 slow_query_log。
查看系统变量

如果要开启慢查询日志,需要在MySQL的配置文件(/etc/my.cnf)中配置如下信息:

#开启MySQL慢日志查询开关
slow_query_log=1
#设置慢日志的时间为2秒,SQL语句执行时间超过2秒,就会视为慢查询,记录慢查询日志
long_query_time=2

配置完毕之后,通过以下指令重新启动MySQL服务器进行测试,查看慢日志文件中记录的信息,/var/lib/mysql/localhost-slow.log。

systemctlrestartmysqld

然后,再次查看开关情况,慢查询日志就已经打开了。

打开慢查询日志

测试:

A. 执行如下SQL语句:

select*fromtb_user;--这条SQL执行效率比较高,执行耗时0.00sec 
selectcount(*)fromtb_sku;--由于tb_sku表中,预先存入了1000w的记录,count一次,耗时
13.35sec

B. 检查慢查询日志:

最终我们发现,在慢查询日志中,只会记录执行时间超多我们预设时间(2s)的SQL,执行较快的SQL是不会记录的。

1691404372187_图片3.png

那这样,通过慢查询日志,就可以定位出执行效率比较低的SQL,从而有针对性的进行优化。


分享到:
在线咨询 我要报名
和我们在线交谈!