MySQL慢查询日志优化实战

1、定位执行慢的SQL:慢查询日志

慢查询日志是记录在MySQL中响应时间超过阈值的语句,具体是说超过long_query_time(他的值默认是10)值的SQL。主要作用是帮助发现那些执行时间特别长的SQL查询,并有针对性的进行优化,从而提高系统整体效率。

默认情况下,MySQL数据库没有开启慢查询日志,如果使用的话需要提前开启。但是如果不是调优需要的话,一般不建议启动该参数,这会带来一定的性能影响。

1.1 开启慢查询日志参数

(1)开启slow_query_log

sql 复制代码
set global slow_query_log = on;

同时,也能看到慢查询日志的文件在/var/lib/mysql/master-slow.log中。

(2)修改long_query_time阈值

将阈值时间设置为1秒,同时对global以及session设置时间。

sql 复制代码
set global long_query_time = 1;

set long_query_time=1;

这是临时修改的,如果想永久设置就必须去配置文件中设置。

1.2 查看慢查询的条数

sql 复制代码
SHOW GLOBAL STATUS LIKE '%Slow_queries%';

1.3 测试分析

(1)测试

新建两个查询,查询时间都大于我们设置的阈值1秒:

sql 复制代码
SELECT * FROM student WHERE stuno = 3455655;
sql 复制代码
SELECT * FROM student WHERE name = 'uPSQCp';

(2)分析

查看慢查询的个数:

sql 复制代码
show status like 'slow_queries'; # 2

1.4 慢查询日志分析工具 mysqldumpslow

sql 复制代码
mysqldumpslow -s t -t 5 /var/lib/mysql/master-slow.log

参数说明:-s是表示按照何种方式排序(t代表查询时间);-t代表返回前面多少条数据;-a表示不把数字抽形成N,字符串抽象成S。如需了解其他用法,可通过执行"mysqldumpslow --help"命令查看详细帮助信息。

1.5 关闭慢查询日志

情况一:如果是在配置文件永久性设置的

sql 复制代码
# ①
slow_query_log=OFF

# ②把slow_query_log一项注释掉 或 删除
# slow_query_log=OFF

然后重启MySQL服务(systemctl restart mysqld)。

情况二:如果是临时性修改的

sql 复制代码
SET GLOBAL slow_query_log=off;

重启MySQL服务,可以查看慢查询日志功能信息:

sql 复制代码
SHOW VARIABLES LIKE '%slow%';
#以及
SHOW VARIABLES LIKE '%long_query_time%';

1.6 删除慢查询日志文件

(1)手动删除慢查询日志文件

(2)重新生成查询日志文件

sql 复制代码
mysqladmin -uroot -p flush-logs slow

如果设置完还没有发现重置后的日志文件,是因为当前状态的慢查询状态是OFF。

2、查看SQL执行成本 SHOW PROFILE

(1)启动show profile

sql 复制代码
 set profiling = 'ON';

(2)当前会话有哪些profiles

sql 复制代码
show profiles;

(3)查看最近一次查询的开销

sql 复制代码
show profile;

(4)查看具体资源消耗

sql 复制代码
show profile cpu,block io for query 2;
相关推荐
段一凡-华北理工大学4 分钟前
工业领域的Hadoop架构学习~系列文章09:HBase列式数据库
数据库·人工智能·hadoop·架构·hbase·高炉炼铁·高炉炼铁智能化
江畔柳前堤8 分钟前
XZ09_Word和MD格式转换
开发语言·数据库·人工智能·python·深度学习·word
移动云开发者联盟11 分钟前
信创版图加速扩展!移动云云数据库Redis通过安全可信认证
数据库·安全
小马爱打代码15 分钟前
SpringBoot + 本地缓存 + 布隆过滤器:防止恶意 ID 查询打穿数据库
数据库·spring boot·缓存
憧憬成为java架构高手的小白15 分钟前
数据库期末复习笔记
数据库·笔记·oracle
10WTW0118 分钟前
个人思考记录(一)What u need in AI era
数据库·mongodb
六月雨滴23 分钟前
Oracle 性能监控体系概述
数据库·oracle·dba
小旭952723 分钟前
MySQL 主从复制、MyCat 读写分离与分库分表实战
java·数据库·sql·mysql·database
计算机安禾23 分钟前
【算法分析与设计】第38篇:最近点对与分治在几何中的应用
java·服务器·网络·数据库·算法
柏舟飞流25 分钟前
向量数据库:从底层原理到选型实战
数据库