【第15天】MYSQL进阶-查询优化-慢查询日志(SQL 小虚竹)_sqlserver慢查询日志

写在最后

为了这次面试,也收集了很多的面试题!

以下是部分面试题截图

Java程序员秋招三面蚂蚁金服,我总结了所有面试题,也不过如此

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

 net stop mysql57

在这里插入图片描述
注:不同的mysql版本,服务名可能不一样,可以去服务里找对应的服务名
在这里插入图片描述
重启mysql服务。

net start mysql57

在这里插入图片描述

查看配置是否生效:

show variables like '%slow\_query\_log%'; 
show variables like '%long\_query\_time%'; 
show variables like '%log\_output%'; 

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

slow_query_log 一直为off,没生效

咦,就slow_query_log 参数没有生效,检查了参数名,没有写错,那会是什么原因呢?

虚竹哥查了下资料,发现在linux下:slow_query_log_file所在的目录需要MySQL的运行帐号的可写权限,如需变更日志文件目录记得给新目录授予777权限,否则slow_query_log一直为OFF

从这个思路扩展一下,会不会mysql也不会帮忙创建不存在的目录。

slow_query_log_file="d:/build/mysql/slow\_statement.log"

在这里插入图片描述
果然没有帮忙创建目录。尝试把目录补上去,再重启下服务试试:
果然生效了
在这里插入图片描述

慢查询日志文件也生成出来了
在这里插入图片描述
画重点:slow_query_log_file指定的文件目录一定要存在的!如果不存在,要手动先创建目录,再重启服务!
画重点:slow_query_log_file指定的文件目录一定要存在的!如果不存在,要手动先创建目录,再重启服务!
画重点:slow_query_log_file指定的文件目录一定要存在的!如果不存在,要手动先创建目录,再重启服务!

验证

执行sql语句,触发慢查询机制:

SELECT BENCHMARK(99999999, MD5('mysql'));

在这里插入图片描述
查看日志内容,如图,已经记录成功:
在这里插入图片描述

linux实战

先创建慢查询日志的存放目录:

mkdir /usr/local/mysql/data/query_log

给目录读写权限

chmod 777 query_log/

在这里插入图片描述

默认该文件的位置是“/etc/mysql/my.cnf”。
虚竹哥自定义my.cnf的位置:/etc/my.cnf
SQL快速入门-安装MYSQL环境(多环境企业级指导)
找到文件:
在这里插入图片描述

修改my.cnf配置:

slow_query_log = 1
slow_query_log_file = /usr/local/mysql/data/query_log/slow_statement.log
long_query_time = 10
log_output = FILE

在这里插入图片描述
保存配置后,重启mysql服务。
查看下mysql服务状态:

systemctl status mysqld

在这里插入图片描述
服务是开启的,先关闭,再启动 。

systemctl stop mysqld

systemctl start mysqld

再查看下mysql服务状态:
在这里插入图片描述
查看配置是否生效:

show variables like ‘%slow_query_log%’;
show variables like ‘%long_query_time%’;
show variables like ‘%log_output%’;

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
慢查询日志文件也生成出来了
在这里插入图片描述
画重点:slow_query_log_file指定的文件目录一定要存在的!如果不存在,要手动先创建目录,再重启服务!
画重点:slow_query_log_file指定的文件目录一定要存在的!如果不存在,要手动先创建目录,再重启服务!
画重点:slow_query_log_file指定的文件目录一定要存在的!如果不存在,要手动先创建目录,再重启服务!

验证

执行sql语句,触发慢查询机制:

SELECT BENCHMARK(99999999, MD5('mysql'));

在这里插入图片描述

查看日志内容,如图,已经记录成功:
在这里插入图片描述

第二种方式

在MySQL命令行中执行命令开启慢查询日志:

SET GLOBAL slow_query_log = 1;
SET GLOBAL slow_query_log_file = '/data/mysql/log/query\_log/slow\_statement.log';
SET GLOBAL long_query_time = 10;
SET GLOBAL log_output = 'FILE';

重点:这种方式不需要重启mysql服务。MySQL重启后会失效。

这种方式不用区分什么操作系统

实操

先查看下慢查询日志的相关参数

show variables like '%slow\_query\_log%'; 
show variables like '%long\_query\_time%'; 
show variables like '%log\_output%'; 

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
我们看到slow_query_log 参数值为OFF,说明慢查询日志未开启。
在MySQL命令行中执行命令开启慢查询日志,其他参数就不设置了,第一种方式有配置了:

SET GLOBAL slow_query_log = 1;

再看下慢查询日志的相关参数,已经开启

show variables like '%slow\_query\_log%'; 

在这里插入图片描述

同时也生成了慢查询日志文件:
在这里插入图片描述

验证

执行sql语句,触发慢查询机制:

SELECT BENCHMARK(99999999, MD5('mysql'));

查看日志内容,如图,已经记录成功:
在这里插入图片描述

关闭慢查询日志

关闭慢查询日志,只需要在my.cnf文件或者my.ini文件中配置slow_query_log=0或者直接删除此选项即可。

第一种方式
windows实战

修改my.ini配置:

# General and Slow logging.
slow_query_log=0

在这里插入图片描述

保存配置后,重启mysql服务。

使用管理员权限打开cmd,在cmd输入以下命令,然后回车:

net stop mysql57

在这里插入图片描述
注:不同的mysql版本,服务名可能不一样,可以去服务里找对应的服务名
在这里插入图片描述
重启mysql服务。

net start mysql57

在这里插入图片描述

手动把之前的慢查询日志先删除:
在这里插入图片描述
查看配置是否生效:

show variables like '%slow\_query\_log%'; 

配置生效:
在这里插入图片描述

验证

执行sql语句,看是否还会触发慢查询机制:

SELECT BENCHMARK(99999999, MD5('mysql'));

结果关闭慢查询日志成功:
在这里插入图片描述

linux实战

修改my.cnf配置:

slow_query_log=0

在这里插入图片描述
保存配置后,重启mysql服务。
查看下mysql服务状态:

systemctl status mysqld

在这里插入图片描述
服务是开启的,先关闭,再启动 。

systemctl stop mysqld

systemctl start mysqld

再查看下mysql服务状态:
在这里插入图片描述
手动把之前的慢查询日志先删除:
在这里插入图片描述

查看配置是否生效:

show variables like '%slow\_query\_log%'; 


配置生效:
在这里插入图片描述

验证

执行sql语句,看是否还会触发慢查询机制:

SELECT BENCHMARK(99999999, MD5('mysql'));


在这里插入图片描述
结果关闭慢查询日志成功:
在这里插入图片描述

第二种方式

在MySQL命令行中执行命令关闭慢查询日志:

SET GLOBAL slow_query_log = 0;

慢查询阀值是10s,改为1s.

set global long_query_time= 1;

修改之后,建议重新开一个会话查询(旧会话查询出的值可能是原来的10s)
重点:这种方式不需要重启mysql服务。MySQL重启后会失效。

扩展
慢查询日志失效原因一:在线动态设置long_query_time,对当前已建立的连接不会生效

查看慢查询日志是否有开启

show variables like '%slow\_query\_log%'; 
show variables like '%long\_query\_time%'; 

在这里插入图片描述
在这里插入图片描述

是已经开启的。如果没有开启,请按上文介绍的方式操作,这里不再赘述。
慢查询阀值是10s,改为1s.

SET GLOBAL long_query_time = 1;

修改之后,建议重新开一个会话查询(旧会话查询出的值可能是原来的10s)
在这里插入图片描述

慢查询日志失效原因二:未使用索引的 SQL 记录不会写入慢查询日志

查看设置,默认是关闭的。

show variables like 'log\_queries\_not\_using\_indexes';

在这里插入图片描述
查看慢查询日志是否有开启

show variables like '%slow\_query\_log%'; 
show variables like '%long\_query\_time%'; 

在这里插入图片描述
在这里插入图片描述

是已经开启的。如果没有开启,请按上文介绍的方式操作,这里不再赘述。

测试sql
检查student 表的索引:

本次面试答案,以及收集到的大厂必问面试题分享:

字节跳动超高难度三面java程序员面经,大厂的面试都这么变态吗?

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取


![在这里插入图片描述](https://i-blog.csdnimg.cn/blog_migrate/88dbc72ec457ee9b16c46d1f41f60c44.png)  
 ![在这里插入图片描述](https://i-blog.csdnimg.cn/blog_migrate/529f6cdfd67f69babcf1e946cf2ab4cc.png)


是已经开启的。如果没有开启,请按上文介绍的方式操作,这里不再赘述。


测试sql  
 检查student 表的索引:



# 本次面试答案,以及收集到的大厂必问面试题分享:

[外链图片转存中...(img-wtBdVHpX-1715487138281)]

> **本文已被[CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】](https://bbs.youkuaiyun.com/forums/4f45ff00ff254613a03fab5e56a57acb)收录**

**[需要这份系统化的资料的朋友,可以点击这里获取](https://bbs.youkuaiyun.com/forums/4f45ff00ff254613a03fab5e56a57acb)**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值