运维开发网

MySQL慢速查询优化解决问题

运维开发网 https://www.qedev.com 2022-07-10 21:38 出处:网络
这篇文章主要介绍了MySQL慢查询优化解决问题,MySQL的慢查询,全名是慢查询日志,是MySQL提供的一种日志记录,用来记录在MySQL中响应时间超过阀值的语句,下文详细介绍慢查询的调优情况,需要的

这篇文章主要介绍了MySQL慢查询优化解决问题,MySQL的慢查询,全名是慢查询日志,是MySQL提供的一种日志记录,用来记录在MySQL中响应时间超过阀值的语句,下文详细介绍慢查询的调优情况,需要的


1. MySQL慢查询介绍

MySQL的慢速查询日志是MySQL提供的日志记录。用于记录MySQL中响应时间超过阈值的语句,具体来说,运行时间超过long_query_time值的SQL会被记录在慢速查询日志中。long_query_time的默认值是10,这意味着运行语句的时间超过10S。默认情况下,Mysql数据库不启动慢速查询日志,所以我们需要手动设置这个参数。当然,如果不是调优所必需的,一般不建议启动该参数,因为启动慢速查询日志会在一定程度上带来一定的性能影响。慢速查询日志支持将日志记录写入文件和数据库表。

与慢速查询日志相关的参数:

MySQL慢速查询相关参数说明:

slow_query_log :是否开启慢查询日志,1表示开启,0表示关闭。log-slow-queries :旧版(5.6以下版本)MySQL数据库慢查询日志存储路径。可以不设置该参数,系统则会默认给一个缺省的文件host_name-slow.logslow-query-log-file:新版(5.6及以上版本)MySQL数据库慢查询日志存储路径。可以不设置该参数,系统则会默认给一个缺省的文件host_name-slow.loglong_query_time :慢查询阈值,当查询时间多于设定的阈值时,记录日志。log_queries_not_using_indexes:未使用索引的查询也被记录到慢查询日志中(可选项)。log_output:日志存储方式。log_output=#39;FILE#39;表示将日志存入文件,默认值是#39;FILE#39;。log_output=#39;TABLE#39;表示将日志存入数据库,这样日志信息就会被写入到mysql.slow_log表中。MySQL数据库支持同时两种日志存储方式,配置的时候以逗号隔开即可,如:log_output=#39;FILE,TABLE#39;。日志记录到系统的专用日志表中,要比记录到文件耗费更多的系统资源,因此对于需要启用慢查询日志,又需要能够获得更高的系统性能,那么建议优先记录到文件。


2.发现问题(主动/被动)

问题:SQL语句在数据库查询时速度太慢

Active:默认情况下,slow_query_log的值为OFF,这意味着慢速查询日志被禁用。

mysqlgt; show variables like '%slow_query_log%';+---------------------+-----------------------------------------------+| Variable_name | Value |+---------------------+-----------------------------------------------+| slow_query_log | OFF || slow_query_log_file | /home/WDPM/MysqlData/mysql/DB-Server-slow.log |+---------------------+-----------------------------------------------+2 rows in set (0.00 sec)mysqlgt; set global slow_query_log=1;Query OK, 0 rows affected (0.09 sec)mysqlgt; show variables like '%slow_query_log%';+---------------------+-----------------------------------------------+| Variable_name | Value |+---------------------+-----------------------------------------------+| slow_query_log | ON || slow_query_log_file | /home/WDPM/MysqlData/mysql/DB-Server-slow.log |+---------------------+-----------------------------------------------+2 rows in set (0.00 sec)

被动:用户告诉页面在使用程序时反应要慢。


3.找到原因-对症下药

原因:无索引,无效索引,极其复杂的SQL,高并发。

1.设计表结构时没有索引,导致

2.SQL语句导致索引失效

索引失效7字符公式:

模:模糊查询LIKE以%开头型:数据类型错误数:对索引字段使用内部函数空:索引列是NULL运:索引列进行四则运算最:复合索引不按索引列最左开始查找快:全表查找预计比索引更快

3.SQL极其复杂,10多个表联合查询。

优化表结构和程序

4.高并发期导致等待。

在程序和数据库之间加入缓存

如果你永不放弃,你的一生将会得到一切。

这就是这篇关于MySQL慢速查询优化问题解决的文章。更多相关MySQL慢查询优化内容

0

精彩评论

暂无评论...
验证码 换一张
取 消