当前位置: 首页 > news >正文

MySQL架构和工作流程

引言:MySQL执行一条sql语句期间发生了什么?

想要搞清楚这个问题,我们必须了解MySQL的体系结构工作流程

一、MySQL体系结构

在这里插入图片描述

MySQL由以下几个部分组成

一、server层

1.MySQL Connnectors连接器,MySQL的连接池组件,网络连接使用io多路复用select处理

主线程:处理连接请求(select)

子线程:对应一条连接,处理该连接的sql请求

也就是说MySQL为每一条客户端连接创建一个线程来专门处理该连接的sql请求,因此,mysql的sql处理是多线程的,所以mysql默认最大连接数为151,过多的线程会占用大量内存

2.查询缓存

对于用户发送的sql查询请求(select)会先在缓存中查找,这个缓存是以key(sql命令)-value(结果)的方式存储的,如果找到则直接返回对应的结果value,没找到则进行下一步

在mysql8.0版本弃用了查询缓存,原因是在实际统计的使用数据中,查询缓存的命中率很低

命中率低的原因是:只要一个表有更新(修改)操作,这个表的查询缓存会被清空,所以每一次的查询缓存都是在该表的最新查询缓存中查找的,而不是所有缓存。因此,表更新则清空缓存的策略是安全且必要的,但是同时使得查询缓存的命中率很低

3.解析器

查询缓存未命中或mysql8.0后的版本,对于一个sql请求,mysql的server层要做的是进行词法语法分析,检查该sql语句是否符合协议,sql语句正确后生成语法树

4.预处理器

1.检查sql语句中指定的表和字段是否存在

2.将 * 替换为表中所有的列名

5.优化器

对于经过预处理的sql语句,优化器负责生成执行计划(执行sql的具体步骤),一般来说,优化器会生成多个执行计划,并选择出一个最优的计划,交由执行器执行

二、存储引擎(mysql使用innodb)

6.执行器

执行器和存储引擎进行交互

一条sql语句的执行流程

1.连接器:建立连接、管理连接、校验用户身份

2.查询缓存(mysql 8.0版本前):sql语句命中缓存则直接返回结果,未命中则继续执行

3.解析sql:进行词法(关键字)句法(语法)分析,生成语法树

4.执行sql:

  • 预处理:检查表和字段是否存在
  • 优化:生成执行计划并选择决定最优计划
  • 执行:执行器使用存储引擎提供的api与之交互

行sql:

  • 预处理:检查表和字段是否存在
  • 优化:生成执行计划并选择决定最优计划
  • 执行:执行器使用存储引擎提供的api与之交互

推荐学习 https://xxetb.xetslk.com/s/p5Ibb

http://www.lryc.cn/news/394344.html

相关文章:

  • java项目总结8
  • 【Nvidia+AI相机】涂布视觉检测方案专注提高锂电池质量把控标准
  • Spring Cloud Alibaba - Sentinel 分布式系统流量哨兵
  • 文件存储的方法一
  • 数据结构/作业/2024/7/7
  • 隔离级别-隔离级别中的锁协议、隔离级别类型、隔离级别的设置、隔离级别应用
  • 【数据结构与算法】希尔排序
  • 【机器学习】(基础篇一) —— 什么是机器学习
  • VitePress安装部署
  • Spring的事务传播机制和隔离级别
  • 华为路由器静态路由配置(eNSP模拟实验)
  • antd实现简易相册,zdppy+vue3+antd实现前后端分离相册
  • PIP换源的全面指南
  • 陶建辉当选 GDOS 全球数据库及开源峰会荣誉顾问
  • Drools开源业务规则引擎(二)- Drools规则语言(DRL)
  • PTA甲级1005:Spell It Right
  • Vue笔记11-Composition API的优势
  • rancher管理多个集群
  • 某大会的影响力正在扩大,吞噬了整个数据库世界!
  • PostgreSQL主从复制:打造高可用数据库架构的秘籍
  • Fast R-CNN(论文阅读)
  • 视觉语言模型:融合视觉与语言的未来
  • 【CSAPP】-linklab实验
  • UE C++ 多镜头设置缩放 平移
  • 代码随想录Day69(图论Part05)
  • 53-1 内网代理3 - Netsh端口转发(推荐)
  • 慧哥充电桩开源平台小程序、PC后、手机商户端历经2年的无数次迭代。
  • 四、(1)网络爬虫入门及准备工作(爬虫及数据可视化)
  • 2024华为OD机试真题-分月饼-(C++/Python)-C卷D卷-200分
  • Git 查看提交历史