Mysql--基础知识点--86--慢查询

1 判断是不是网络、接口问题;
2 若不是网络接口问题,查看服务器性能cpu、内存、硬盘。若mysql的cpu很高则表示读写频率高,若网站的访问量又不高,则可能是(1)mysql参数问题;(2)linux系统参数;(3)mysql的sql语句查询慢的问题。
2.1 mysql参数的问题,采取措施:(i) 调整缓存池大小 (ii)调整连接数大小。
2.2 linux系统参数,采取措施:(i) 调整文件句柄数 (ii) 调整tcp连接TIMEWAIT状态相关参数;MySQL–基础知识点–55–MySQL优化中系统内核优化部分
2.3 mysql的sql语句查询慢问题,采取措施:(i) 使用show processlist; 查询当前活动连接,可以显现出谁在执行sql,以及正在执行的sql执行了多长时间。(ii) 使用慢查询日志查看慢查询sql [@1 查询慢查询日志三个相关参数:show variables like ‘query’; @2 三个慢查询日志参数:slow_query_time 慢查询时间阈值,超过这个时间的查询的查询语句会被记录到慢查询日志里;slow_query_log 是否打开慢查询,值为off/on;slow_query_log_file 慢查询日志的位置;@3 启用慢查询 set global slow_query_log=ON @4 摸拟一条慢查询 select * from edu_user where id=1 and sleep(60);] @4 mysqldumpslow 分析慢查询日志,访问最慢的sql、查询频次最高的sql等。(iii) explain分析慢查询sql执行任务,通过查看 EXPLAIN 的输出,你可以了解查询的性能瓶颈,并据此进行优化。例如,如果你发现查询没有使用索引,或者查询了过多的行,那么你可能需要重新考虑索引策略,或者修改查询以使其更高效。(iv)表结构优化:@1 没索引加索引; @2 有索引的对索引进行优化 (v) 查询语句的优化MySQL–基础知识点–55–MySQL优化中SQL优化部分
3 若以上都没问题,考虑数据量大的问题。措施:(i) 读写分离;(ii) 应用级别的缓存;(iii)分库分表分区。

补充:

mysqldumpslow是MySQL提供的一个命令行工具,主要用于分析MySQL的慢查询日志(slow query log)。以下是关于mysqldumpslow的详细介绍和使用方法:
 
一、基本用途
分析慢查询日志:从慢查询日志中提取信息,并以易读的方式展示最耗时的查询,以便进一步分析和优化。
提高性能:帮助开发人员和数据库管理员识别和优化数据库中的慢查询,提高系统的性能和响应时间。
二、使用方法
查看慢查询日志
在命令行中输入mysqldumpslow /path/to/slowquery.log,以查看整个慢查询日志文件中的所有慢查询。
排序选项
-s参数用于指定排序方式,可以按查询时间、锁等待时间、返回行数等进行排序。
-s t:按时间顺序(从最新到最旧)排序。
-s at:按查询时间长短排序,显示查询时间最长的慢查询。
-s al:按锁等待时间长短排序。
-s ar:按返回行数排序。
指定显示的记录数
-t NUM参数用于指定显示多少条慢查询记录。默认情况下,mysqldumpslow将显示前10条慢查询记录。
过滤特定的查询
使用-g PATTERN参数进行正则匹配,筛选出与特定模式相关的慢查询。
其他选项
-v:输出debug信息。
-d:指定输出排序规则,包括多种排序方式的组合。
-r:输出结果反序排序,默认是降序(desc)排序。
-a:不将数字抽象为N、字符抽象为S。
-n NUM:将超过N个数字的数值字符抽象显示。
-l:总时间包含锁定时间。
三、注意事项
在使用mysqldumpslow之前,需要确保MySQL的慢查询日志功能已经开启,并且慢查询日志文件存在且可读取。
mysqldumpslow工具通常与MySQL数据库服务器一起安装,无需单独安装。
虽然mysqldumpslow提供了基本的慢查询分析功能,但对于更复杂的性能问题,可能需要结合其他工具和方法进行综合分析和优化。
通过合理地使用mysqldumpslow工具,可以有效地识别和优化MySQL数据库中的慢查询,提高系统的整体性能和响应速度。

EXPLAIN 是 MySQL 中的一个关键字,用于分析 SQL 查询的执行计划。当你对查询性能有疑问,或者想知道 MySQL 是如何执行某个查询时,EXPLAIN 可以提供非常有价值的信息。
 
使用 EXPLAIN 的基本语法是:

EXPLAIN SELECT ... FROM ... WHERE ...;
eg: EXPLAIN SELECT * FROM users WHERE username = 'john_doe';

当你执行一个带有 EXPLAIN 的查询时,MySQL 不会实际执行这个查询,而是返回一个关于查询执行划的表格。这个表格包含了多个列,每个列都提供了关于查询执行的不同方面的信息。
想知道 MySQL 是如何执行某个查询时,EXPLAIN 可以提供非常有价值的信息。
 
以下是一些常见的 EXPLAIN 输出列及其描述:
想知道 MySQL 是如何执行某个查询时,EXPLAIN 可以提供非常有价值的信息。

  • id:查询标识符,每个 SELECT(和某些子查询)都会有一个唯一的 ID。
  • select_type:查询的类型(例如 SIMPLE、SUBQUERY、UNION 等)。
  • table:查询涉及的表。
  • type:连接类型(例如 ALL、index、range、ref、eq_ref、const 等),它告诉你 MySQL 如何连接表。ref 和 const 通常是好的,而 ALL 则可能表示性能问题。
  • possible_keys:查询可能使用的索引。
  • key:实际使用的索引(如果 MySQL 决定使用索引的话)。
  • key_len:使用的索引的长度。
  • ref:哪些列或常量被用作索引查找的引用。
  • rows:MySQL 估计需要检查的行数(注意,这只是一个估计值)。
  • Extra:包含 MySQL 解决查询的附加信息(例如使用了哪些文件排序、使用了临时表等)。
    想知道 MySQL 是如何执行某个查询时,EXPLAIN 可以提供非常有价值的信息。

 
通过查看 EXPLAIN 的输出,你可以了解查询的性能瓶颈,并据此进行优化。例如,如果你发现查询没有使用索引,或者查询了过多的行,那么你可能需要重新考虑索引策略,或者修改查询以使其更高效。

2.3.iv,@2

  • 最左前缀匹配原则,组合索引非常重要的原则,mysql会一直向右匹配直到遇到范围查询(>、<、between、like)就停止匹配,比如a = 1 and b = 2 and c > 3 and d = 4 如果建立(a,b,c,d)顺序的索引,d是用不到索引的,如果建立(a,b,d,c)的索引则都可以用到,a,b,d的顺序可以任意调整。
  • 较频繁作为查询条件的字段才去创建索引
    更新频繁字段不适合创建索引
  • 若是不能有效区分数据的列不适合做索引列(如性别,男女未知,最多也就三种,区分度实在太低)
  • 尽量的扩展索引,不要新建索引。比如表中已经有a的索引,现在要加(a,b)的索引,那么只需要修改原来的索引即可。
  • 定义有外键的数据列一定要建立索引。
  • 对于那些查询中很少涉及的列,重复值比较多的列不要建立索引。
  • 对于定义为text、image和bit的数据类型的列不要建立索引。最左前缀匹配原则,组合索引非常重要的原则,mysql会一直向右匹配直到遇到范围查询(>、<、between、like)就停止匹配,比如a = 1 and b = 2 and c > 3 and d = 4 如果建立(a,b,c,d)顺序的索引,d是用不到索引的,如果建立(a,b,d,c)的索引则都可以用到,a,b,d的顺序可以任意调整。
  • 较频繁作为查询条件的字段才去创建索引
  • 更新频繁字段不适合创建索引
  • 若是不能有效区分数据的列不适合做索引列(如性别,男女未知,最多也就三种,区分度实在太低)
  • 尽量的扩展索引,不要新建索引。比如表中已经有a的索引,现在要加(a,b)的索引,那么只需要修改原来的索引即可。
  • 定义有外键的数据列一定要建立索引。
  • 对于那些查询中很少涉及的列,重复值比较多的列不要建立索引。
  • 对于定义为text、image和bit的数据类型的列不要建立索引。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/713903.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

FPGA - 数 - 加减乘除

一&#xff0c;数的表示 首先&#xff0c;将二进制做如下解释&#xff1a; 2的0次方1 2的1次方2 2的2次方4 2的3次方8 ..... 以此类推&#xff0c;那么任何整数&#xff0c;或者说任意一个自然数均可以采用这种方式来表示。 例如&#xff0c;序列10101001&#xff0c;根据上述…

ThinkPHP邮件发送配置教程?怎么配置群发?

ThinkPHP邮件发送安全性如何保障&#xff1f;ThinkPHP如何实现&#xff1f; 无论是用户注册后的验证邮件&#xff0c;还是订单处理的通知邮件&#xff0c;都需要一个可靠的邮件发送机制。AokSend将详细介绍如何在ThinkPHP框架中配置邮件发送功能&#xff0c;并带您逐步了解其中…

JavaScript常见面试题(一)

文章目录 1. JavaScript有哪些数据类型&#xff0c;它们的区别&#xff1f;2.数据类型检测的方式有哪些3. 判断数组的方式有哪些4.null和undefined区别5.typeof null 的结果是什么&#xff0c;为什么&#xff1f;6.intanceof 操作符的实现原理及实现7.为什么0.10.2 ! 0.3&…

【Go语言】Gin 框架教程

Gin 框架教程 1.第一个 Gin 程序 1.1 Gin 安装 # 执行执行如下操作即可&#xff0c;安装Gin前需要安装Go环境 go get -u -v github.com/gin-gonic/gin # -v&#xff1a;打印出被构建的代码包的名字 # -u&#xff1a;已存在相关的代码包&#xff0c;强行更新代码包及其依赖包…

转让中字头控股集团公司步骤和条件

随着中国经济的不断发展&#xff0c;越来越多的企业开始积极寻求并购和收购机会。其中&#xff0c;国家总局中字头控股集团公司也是一个备受关注的对象。本篇文章将为您详细介绍国家总局中字头控股集团公司的收购流程及要求。详情致电咨询我或者来公司面谈。 中字头公司转让需满…

[DDR4] DDR4 相对 DDR3差异与优势

依公知及经验整理&#xff0c;原创保护&#xff0c;禁止转载。 传送门: 总目录 1 差异总览 出处&#xff1a; https://www.kingston.com.cn/en/memory/ddr4-overview Description 描述DDR3DDR4Advantage 优势电压1.5V1.2V降低内存功耗需求容量512Mb-8Gb4Gb-16Gb更大的 DIMM 容…

AI 定位!GeoSpyAI上传一张图片分析具体位置 不可思议! ! !

&#x1f3e1;作者主页&#xff1a;点击&#xff01; &#x1f916;常见AI大模型部署&#xff1a;点击&#xff01; &#x1f916;Ollama部署LLM专栏&#xff1a;点击&#xff01; ⏰️创作时间&#xff1a;2024年6月16日12点23分 &#x1f004;️文章质量&#xff1a;94分…

快速UDP网络连接之QUIC协议介绍

文章目录 一、QUIC协议历史1.1 问题&#xff1a;QUIC为什么在应用层实现1.2 QUIC协议相关术语1.3 QUIC和TCP对比1.4 QUIC报文格式1.4.1 QUIC报文格式-Stream帧11.4.2 QUIC报文格式-Stream帧2 二、QUIC的特点2.1 连接建立低时延&#xff0c;2.2 多路复用流复用-HTTP1.1流复用-HT…

【OS基础】符合AUTOSAR标准的RTAOS-Alarms详解

目录 前言 正文 7.报警Alarms 7.1配置Alarms 7.1.1激活一个任务 7.1.2 设置一个事件 7.1.3报警回调Alarm Callback 7.1.4 增加计数器值 7.2设置Alarms 7.2.1 绝对Alarms 7.2.2 相对Alarm 7.3自启动Alarms 7.4 删除Alarms 7.5确认何时会发生Alarm 7.6非周期Alarm…

EMQX集群搭建

1. 什么是 MQTT&#xff1f; MQTT&#xff08;Message Queuing Telemetry Transport&#xff09;是一种轻量级、基于发布-订阅模式的消息传输协议&#xff0c;适用于资源受限的设备和低带宽、高延迟或不稳定的网络环境。它在物联网应用中广受欢迎&#xff0c;能够实现传感器、…

DETR实现目标检测(一)-训练自己的数据集

1、DETR架构 DETR&#xff08;Detection Transformer&#xff09;是一种新型的目标检测模型&#xff0c;由Facebook AI Research (FAIR) 在2020年提出。DETR的核心思想是将目标检测任务视为一个直接的集合预测问题&#xff0c;而不是传统的两步或多步预测问题。这种方法的创新…

FPGA IO_BANK、IO_STANDARD

描述 Xilinx 7系列FPGA和UltraScale体系结构提供了高性能&#xff08;HP&#xff09;和 高范围&#xff08;HR&#xff09;I/O组。I/O库是I/O块&#xff08;IOB&#xff09;的集合&#xff0c;具有可配置的 SelectIO驱动程序和接收器&#xff0c;支持多种标准接口 单端和差分。…

vxe-table表格新增节点

做前端的朋友可以参考下&#xff1a;也可结合实际需求查看相应的官方文档 效果图 附上完整代码 <template><div><vxe-toolbar ref"toolbarRef" :refresh"{queryMethod: searchMethod}" export print custom><template #buttons>&…

React写一个 Modal组件

吐槽一波 最近公司的项目终于度过了混乱的前期开发&#xff0c;现在开始有了喘息时间可以进行"规范"的处理了。 组件的处理&#xff0c;永远是前端的第一大任务&#xff0c;尤其是在我们的ui库并不怎么可靠的情况下&#xff0c;各个组件的封装都很重要&#xff0c;而…

minium小程序自动化

一、安装minium pip install minium二、新建config.json {"dev_tool_path": "D:\\Program Files (x86)\\Tencent\\微信web开发者工具\\cli.bat","project_path": "小程序项目路径" }三、编写脚本 import miniumclass FirstTest(min…

【Echarts系列】平滑折线面积图

【Echarts系列】平滑折线面积图 序示例数据格式代码 序 为了节省后续开发学习成本&#xff0c;这个系列将记录我工作所用到的一些echarts图表。 示例 平滑折线面积图如图所示&#xff1a; 数据格式 data [{name: 2020年,value: 150},{name: 2021年,value: 168},{name: 2…

设计模式-装饰器模式Decorator(结构型)

装饰器模式(Decorator) 装饰器模式是一种结构模式&#xff0c;通过装饰器模式可以在不改变原有类结构的情况下向一个新对象添加新功能&#xff0c;是现有类的包装。 图解 角色 抽象组件&#xff1a;定义组件的抽象方法具体组件&#xff1a;实现组件的抽象方法抽象装饰器&…

git的ssh安装,windows通过rsa生成密钥认证问题解决

1 windows下载 官网下载可能出现下载太慢的情况&#xff0c;Git官网下载地址为&#xff1a;官网&#xff0c;推荐官网下载&#xff0c;如无法下载&#xff0c;可移步至CSDN&#xff0c;csdn下载地址&#xff1a;https://download.csdn.net/download/m0_46309087/12428308 2 Gi…

【Linux】程序地址空间之动态库的加载

我们先进行一个整体轮廓的了解&#xff0c;随后在深入理解细节。 在动态库加载之前还要说一下程序的加载&#xff0c;因为理解了程序的加载对动态库会有更深的理解。 轮廓&#xff1a; 首先&#xff0c;不管是程序还是动态库刚开始都是在磁盘中的&#xff0c;想要执行对应的可…

PHP在线生成查询产品防伪证书系统源码

源码介绍 PHP在线生成查询产品防伪证书系统源码&#xff0c;源码自带90套授权证书模板&#xff0c;带PSD公章模板&#xff0c;证书PSD源文件。 环境要求&#xff1a;PHPMYSQL&#xff0c;PHP 版本请使用PHP5.1 ~5.3。 图片截图 源码安装说明 1.上传所有文件至你的空间服务器…