慢SQL问题全解析:原因诊断与性能优化策略

ops/2024/10/20 14:49:20/

慢SQL的定义:

        执行时间长的

慢SQL的筛选:

1.使用MySQL自带的日志

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

SHOW VARIABLES LIKE '%slow_query_log%';

开启慢查询日志:使用该方法开启MySQL的慢查询日志只对当前数据库生效,如果MySQL重启后会失效。

SET GLOBAL slow_query_log = 1;
2.Druid数据库连接池

Druid连接池MySQL配置1

Druid连接池MySQL配置2

3.自己实现:

借助AOP记录时间:自己使用AOP记录每一个SQL执行的时间

引起慢SQL的原因:

资源不足:
  •  线程太多
    • 查看CPU负载:top指令
    • 查看进程的负载:
  • 内存不足
    • 查看内存占用:top
    • 查看硬盘的使用情况:df -h
  • 数据量太大
    • 插入数据库数据量太大:分批插入:从500条开始,逐步增长批量条数
    • 查询的数据量比较大:
      • 分库分表
      • 限定查询条件
      • 读写分离:适合查询次数非常高,更新频次非常高
  • 网络不好
    • 判断网络使用情况:netstat
错误使用
  • SQL使用不当
  • 数据量太大
  • 网络不好
  • 表设计不当
  • 查询条件太多
  • 解决慢SQL
  • 索引失效
    • 联合索引不满足最左匹配原则

      联合索引遵从最左匹配原则,顾名思义,在联合索引中,最左侧的字段优先匹配。因此,在创建联合索引时,where子句中使用最频繁的字段放在组合索引的最左侧。

      而在查询时,要想让查询条件走索引,则需满足:最左边的字段要出现在查询条件中。

    • 使用了select *

    • 索引列参与运算

    • 索引列参使用了函数

    • 错误的Like使用

      • 占位符出现在首部
    • 参数类型与字段类型不匹配,导致类型发生了隐式转换,索引失效。

      • id_no字段类型为varchar,但在SQL语句中使用了int类型,导致全表扫描。

        出现索引失效的原因是:varchar和int是两个种不同的类型。

    • 查询条件使用or关键字,其中一个字段没有创建索引,则会导致整个查询语句索引失效; or两边为“>”和“<”范围查询时,索引失效。

    • 如果两个列数据都有索引,但在查询条件中对两列数据进行了对比操作,则会导致索引失效。

    • 查询条件使用不等进行比较时,需要慎重,普通索引会查询结果集占比较大时索引会失效

    • 查询条件使用is null时正常走索引,使用is not null时,不走索引

    • 查询条件使用not in时,如果是主键则走索引,如果是普通索引,则索引失效

    • 查询条件使用not exists时,索引失效

    • 当查询条件涉及到order by、limit等条件时,是否走索引情况比较复杂,而且与Mysql版本有关,通常普通索引,如果未使用limit,则不会走索引。order by多个索引字段时,可能不会走索引。其他情况,建议在使用时进行expain验证。

    • 当查询条件为大于等于、in等范围查询时,根据查询结果占全表数据比例的不同,优化器有可能会放弃索引,进行全表扫描。

    • Mysql优化器的其他优化策略,比如优化器认为在某些情况下,全表扫描比走索引快,则它就会放弃索引。

EXPLAIN +SQL语句 可以对SQL语句模拟优化器执行SQL查询语句

key

keylen

ref

参考文章:15个必知的Mysql索引失效场景,别再踩坑了-腾讯云开发者社区-腾讯云 (tencent.com)


http://www.ppmy.cn/ops/23957.html

相关文章

算法提高 第一期 KMP扩展算法

1## 具体思路&#xff1a; 和KMP算法的是想类似&#xff0c;充分利用已经比较字符性质来减少冗余的字符比较次数。KMP的思想是充分的利用模式串中所有前缀字串&#xff08;以模式串为开头的字串&#xff09;的真前缀和真后缀&#xff08;指子串的开始字符与子串的最后字符相等的…

verilog分析task的接口设计,证明这种写法:assign {a,b,c,d} = links;

verilog分析task的接口设计&#xff0c;证明这种写法&#xff1a;assign {a,b,c,d} links; 1&#xff0c;task在状态机中的使用好处&#xff1a;2&#xff0c;RTL设计3&#xff0c;测试testbench4&#xff0c;波形分析&#xff0c;正确&#xff01; 参考文献&#xff1a; 1&am…

2024.04.10校招 实习 内推 面经

绿*泡*泡VX&#xff1a; neituijunsir 交流*裙 &#xff0c;内推/实习/校招汇总表格 1、校招 | 蔚来校招 硬核造车&#xff0c;等你投递&#xff08;内推&#xff09; 校招 | 蔚来校招 硬核造车&#xff0c;等你投递&#xff08;内推&#xff09; 2、校招 | 华大半导体2024…

如何一键清除文件目录下所有的node_modules

如何一键清除文件目录下所有的node_modules 快速删除目录下的node_modules&#xff0c;下面附上windows和mac的脚本指令 windows脚本 FOR /d /r . %d in (node_modules) DO IF EXIST "%d" rm -rf "%d"mac脚本 find . -name "node_modules" -…

React的状态管理useState

基础使用 useState 是一个 React Hook&#xff08;函数&#xff09;&#xff0c;它允许我们向组件添加一个状态变量, 从而控制影响组件的渲染结果和普通JS变量不同的是&#xff0c;状态变量一旦发生变化组件的视图UI也会跟着变化&#xff08;数据驱动视图&#xff09; useState…

【Docker】常见命令汇总

1 镜像相关 1.1 查看镜像 # 查看镜像列表 docker images# 查看具体的镜像: sudo docker images <镜像名称> docker images centos # 指定具体 tag: sudo docker images centos:<tag> docker images centos:7.8.2003# 查看镜像 ID 列表: --q/--quiet docker ima…

gateway全局token过滤器

添加gateway依赖 <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId></dependency>创建一个tokenFilter 实现全局过滤器GlobalFilter,并且实现fitler方法 Value("${…

关于discuz论坛网址优化的一些记录(伪静态)

最近网站刚上线&#xff0c;针对SEO做了些操作&#xff0c;为了方便网站网页被收录&#xff0c;特此记录下 1.开启伪静态 按照操作勾选所有项&#xff0c;然后点击查看伪静态规则 2.打开宝塔&#xff0c;找到左侧列表的网站&#xff0c;然后找到相应站点的设置。把discuz自动…