【第15天】MYSQL进阶-查询优化-慢查询日志(SQL 小虚竹)
回城传送–》《100天精通MYSQL从入门到就业》
文章目录
- 零、前言
- 一、练习题目
- 二、SQL思路:SQL进阶-查询优化-慢查询日志
- 初始化数据
- 解法
- 慢查询日志是什么
- 如何开启慢查询日志
- 第一种方式
- windows实战
- slow_query_log 一直为off,没生效
- 验证
- linux实战
- 验证
- 第二种方式
- 实操
- 验证
- 关闭慢查询日志
- 第一种方式
- windows实战
- 验证
- linux实战
- 验证
- 第二种方式
- 扩展
- 慢查询日志失效原因一:在线动态设置long_query_time,对当前已建立的连接不会生效
- 慢查询日志失效原因二:未使用索引的 SQL 记录不会写入慢查询日志
- 慢查询日志失效原因三:慢sql里有锁等待
- 慢查询日志失效原因四:默认不记录管理类命令的慢sql
- 慢查询日志失效原因五:min_examined_row_limit为非0
- 慢查询日志失效原因六:slow log文件句柄发生了变化
- 慢查询日志失效原因七:从库的复制语句默认不记录
- 三、总结
- 四、参考
零、前言
今天是学习 SQL 打卡的第 15 天,每天我会提供一篇文章供群成员阅读( 不需要订阅付钱 )。
希望大家先自己思考,如果实在没有想法,再看下面的解题思路,自己再实现一遍。在小虚竹JAVA社区 中对应的 【打卡贴】打卡,今天的任务就算完成了,养成每天学习打卡的好习惯。
虚竹哥会组织大家一起学习同一篇文章,所以有什么问题都可以在群里问,群里的小伙伴可以迅速地帮到你,一个人可以走得很快,一群人可以走得很远,有一起学习交流的战友,是多么幸运的事情。
我的学习策略很简单,题海策略+ 费曼学习法。如果能把这些题都认认真真自己实现一遍,那意味着 SQL 已经筑基成功了。后面的进阶学习,可以继续跟着我,一起走向架构师之路。
今天的学习内容是:SQL进阶-查询优化-慢查询日志
一、练习题目
题目链接 | 难度 |
---|---|
SQL进阶-查询优化-慢查询日志 | ★★★☆☆ |
二、SQL思路:SQL进阶-查询优化-慢查询日志
初始化数据
drop table if exists student;
CREATE TABLE `student` (
`id` int NOT NULL AUTO_INCREMENT COMMENT '自增ID',
`order_num` long NOT NULL COMMENT '序号',
`student_name` varchar(20) NOT NULL COMMENT '姓名',
`age` int COMMENT '年龄',PRIMARY KEY (`id`))ENGINE=InnoDB CHARACTER SET utf8 COLLATE utf8_general_ci;
插入100万条数据,这里使用了存储过程,进行批量提交数据,先关闭自动提交,插入一定条数再进行提交。
--创建存储过程drop procedure if exists add_student;CREATE PROCEDURE `add_student`(in n int,in batchNum int)
BEGINDECLARE i INT DEFAULT 1;WHILE (i < n+1 ) DOset autocommit = 0;INSERT into student (order_num,student_name,age) VALUES (i,concat('student_name',i),20);set i=i+1;if i mod batchNum = 0 thencommit;end if;END WHILE;commit;
END
-- 调用
CALL add_student(1000000,100000)
解法
要求处理:
- 从四个选项中选择一个正确答案
分析:
慢查询日志是什么
mysql支持执行超过一定时间long_query_time 的sql语句记录到日志里,方便开发或dba人员去优化sql语句。超过一定时间:这个是可以由参数long_query_time 进行配置。
如何开启慢查询日志
第一种方式
可以在mysql的配置文件里开启慢查询日志。
mysql中“my.ini”文件:
- 1、linux系统中,默认该文件的位置是“/etc/mysql/my.cnf”;
- 2、windows系统中,默认该文件的位置是“C:\ProgramData\MySQL\MySQL Server **\Data\my.ini”。
其中C:\ProgramData是隐藏目录,需要显示隐藏目录才能找到。
[mysqld]
slow_query_log = 1
slow_query_log_file = /data/mysql/log/query_log/slow_statement.log
long_query_time = 10
log_output = FILE
配置项说明:
slow_query_log:1代表开启慢查询日志。0:代表关闭慢查询日志。
slow_query_log_file:慢查询日志保存的地方和对应的文件名。
long_query_time:指定SQL语句执行时间超过多少秒时记录慢查询日志。
log_output:File:表示将日志存入文件,默认值是’FILE’;Table:表示将日志存入数据库,这样日志信息就会被写入到mysql.slow_log表中。
经验之谈:当记录到数据表中时,则数据表中记录的慢查询时间只能精确到秒;如果是记录到日志文件中,则日志文件中记录的慢查询时间能够精确到微秒。
建议在实际工作中,将慢查询日志记录到文件中。
重点:配置完成后,要重启mysql服务器!配置才会生效!
windows实战
默认该文件的位置是“C:\ProgramData\MySQL\MySQL Server **\Data\my.ini”。
找到文件:
修改my.ini配置:
# General and Slow logging.
slow_query_log=1
slow_query_log_file="d:/build/mysql/slow_statement.log"
long_query_time=10
log_output=FILE
保存配置后,重启mysql服务。
使用管理员权限打开cmd,在cmd输入以下命令,然后回车:
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 mysqldsystemctl 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 mysqldsystemctl 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 表的索引:
show index from student;
执行没有使用索引的sql:
select *
from student
where student_name ='student_name446741'
慢查询日志中,并没有记录到。
设置没使用索引的 SQL 记录写入慢查询日志:
set global log_queries_not_using_indexes=on;
再执行慢查询的sql
select *
from student
where student_name ='student_name446741'
没有索引的数据也添加到慢查询日志了。
注:log_queries_not_using_indexes参数要跟参数log_throttle_queries_not_using_indexes配合使用
log_throttle_queries_not_using_indexes:该参数决定每分钟记录未使用索引的SQL的数量上限,因为未使用索引的SQL可能会非常多,导致慢日志空间增长飞快。
慢查询日志失效原因三:慢sql里有锁等待
慢SQL里有大量锁等待,慢SQL的执行时间不包含锁等待的时间
慢查询日志失效原因四:默认不记录管理类命令的慢sql
log_slow_admin_statements=0,因此alter, create index, analyze table等操作即使超过 long_query_time,也不会记录到慢日志中。
log_slow_admin_statements 该参数决定是否记录管理类的命令,有 ALTER TABLE,ANALYZE TABLE, CHECK TABLE, CREATE INDEX, DROP INDEX, OPTIMIZE TABLE,REPAIR TABLE,默认是不记录这一类语句到慢日志。
慢查询日志失效原因五:min_examined_row_limit为非0
min_examined_row_limit 该参数定义一个SQL所读取的数据行数;
min_examined_row_limit设置为非0值,SQL检查行数未超过该值,也不会记录。
默认值为0
慢查询日志失效原因六:slow log文件句柄发生了变化
slow log文件钻句柄发生了变化,如运行期间用vim打开log,最后又保存退出,此时文件句柄发生变化,需要执行flush slow logs。
慢查询日志失效原因七:从库的复制语句默认不记录
log_slow_slave_statements:该参数在从库上设置,决定是否记录在复制过程中超过long_query_time的SQL,如果binlog格式是row,则即使开启了该参数,也不会记录相关SQL。
除非binlog格式是statement且开启log_slow_slave_statements。
三、总结
本文介绍了慢查询日志在windows环境和Linux环境如何开启和关闭,开启和关闭分别介绍了两种方式来操作,一种是通过修改配置,重启服务生效;另一种是通过命令快速生效,但MySQL重启后会失效。
可以根据实际的业务场景进行选择。
额外补充了慢查询日志的七个失效原因,都是从实战中摸索出来的宝贵经验。
所以,嗯,这题的答案选。。评论区大声告诉虚竹哥。
四、参考
MySQL进阶技能树–>慢查询日志
我是虚竹哥,我们明天见~
【第15天】MYSQL进阶-查询优化-慢查询日志(SQL 小虚竹)相关推荐
- 【第18天】SQL进阶-查询优化- SHOW PROFILE(SQL 小虚竹)
回城传送–><32天SQL筑基> 文章目录 零.前言 一.练习题目 二.SQL思路 SQL进阶-查询优化- SHOW PROFILE 初始化数据 解法 SHOW PROFILE是什么 ...
- 《MySQL数据库进阶实战》读后感(SQL 小虚竹)
❤️作者主页:小虚竹 ❤️作者简介:大家好,我是小虚竹.Java领域优质创作者
- Mysql进阶学习所用到的SQL测试库代码
Mysql进阶学习所用到的SQL测试库代码 一.`myemployees`库 二.`girls`库 一.myemployees库 /* SQLyog Ultimate v10.00 Beta1 MyS ...
- 李玉婷老师MYSQL进阶01-基础查询
李玉婷老师MYSQL进阶01 DQL语言的学习 基础查询 ★ 条件查询 ★ 排序查询 ★ 常见函数 ★ 分组函数 ★ 分组查询 ★ 连接查询 ★ 子查询 √ 分页查询 ★ union联合查询 √ 进阶 ...
- 【第21天】SQL进阶-查询优化- performance_schema系列三:事件记录(SQL 小虚竹)
回城传送–><32天SQL筑基> 文章目录 零.前言 一.练习题目 二.SQL思路 SQL进阶-查询优化- performance_schema系列三:事件记录 等待事件表 even ...
- mysql开启查看慢查询日志[转]
为什么80%的码农都做不了架构师?>>> 1,配置开启 在mysql配置文件my.cnf中增加 log-slow-queries=/var/lib/mysql/slowquer ...
- Mysql(三) Mysq慢查询日志
Mysql Slow Query Log MYSQL慢查询日志是用来记录执行时间超过指定时间的查询语句.通过慢查询日志,可以查找出哪些查询语句的执行效率很低,以便进行优化.一般建议开启,它对服务器性能 ...
- mysql errcode13_MySQL开启慢查询日志时报Errcode: 13 的解决方法
开启慢查询日志时会出现(Errcode: 13 - Permission denied)文件找不到的错误,但文件明明是存在的并且有读写的权限. mysql> set global slow_qu ...
- mysql数据库开启慢查询日志
修改配置文件 在配置文件my.ini中加上下面两句话 1 log-slow-queries = C:\xampp\mysql_slow_query.log 2 long_query_time=3 第一 ...
- 李玉婷MYSQL进阶08——分页查询
分页查询 应用场景:当要显示的数据,一页显示不全,需要分页提交sql要求 语法: select 查询列表 from 表 [join type join 表2 on 连接条件 where 筛选条件 gr ...
最新文章
- “计算机艺术之父”、现代计算机技术先驱查理斯·苏黎去世,享年99岁!
- 解决向数据库mysql插入double数据小数点不显示问题
- 怎么提升软件测试质量,【软件测试】涨姿势,测试总监亲授如何做测试质量管理...
- 97. Leetcode 剑指 Offer 60. n个骰子的点数 (动态规划-背包问题)
- Qt工作笔记-pro文件中QMAKE_POST_LINK的使用
- 定位html中的背景图,关于背景图的定位和透明度问题(HTML+CSS笔记)
- Windows Mobile 5.0新增API介绍(转自MSDN)
- hashmap value占用空间大小_性能优化:为什么要使用SparseArray和ArrayMap替代HashMap?...
- x64位xp连接位于32位xp系统上的打印机
- 谐振放大器工作点和阻抗
- 网红必备神器,抖音短视频去水印秘籍-抖音-快手-微视-全名小视频
- 计算机网络分层结构概述
- 异构网络-元图、知识图谱
- Node.js 更新到最新版本
- UVA - 1600 Patrol Robot (巡逻机器人)(bfs)
- Alpine介绍与apk的基本使用
- c语言 多字节合并拼接(4个uchar 组合成 ulong)
- 科研日记1——RSOFT层状结构波导背景折射率?
- 安卓嵌入H5的方式 腾讯人脸识别核身 身份验证 点击开始录制按钮 没有反应 鸿蒙系统
- 360推广如何提高权重
热门文章
- 【渝粤教育】国家开放大学2018年春季 0686-22T广告创意与表现(一) 参考试题
- 深度操作系统服务器版v15,深度操作系统 15.7 —— 性能好才是真的好
- PSP - 基于扩散生成模型预测蛋白质结构 EigenFold 算法与环境配置
- 2009年三月全国计算机二级,2009年3月全国计算机等级考试二级笔试试卷
- 价格战将毁掉大陆手机产业?
- 关于html,css学习回顾一总结,闭组会议总结
- python离群点检测_包会!手把手教你机器学习(零基础)之异常点检测
- Catalogue in Markdown
- 集成学习(上)偏差与方差理论
- 属于爸爸们的SVG模版