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

01 | Msyql系统架构

目录

  • MySQL系统架构
    • 连接器
    • 查询缓存
    • 分析器
    • 优化器
    • 执行器


MySQL系统架构

在这里插入图片描述
大体来说,MySQL分为Server层和引擎层两部分。

Server层包含链接器、查询缓存、分析器、优化器和执行器,而引擎层负责的是数据的存储和读取,支持InnoDB、Myisam、Memory等多种存储引擎,默认InnoDB。

连接器

mysql -h$ip -P$port -u$user -p

如果输入的密码不对,会收到Access denied for user的错误;如果输入密码正确,连接器会查询出权限表中此账户所拥有的权限,这个连接后续所有的权限判断、都依赖于此时查出来的权限。

这就意味着,一个用户成功建立连接后,即使你用管理员账号对这个用户的权限做了修改,也不会影响已经存在连接的权限。修改完成后,只有再新建的连接才会使用新的权限设置。可以通过show processlist;命令查看已经建立的连接
在这里插入图片描述

连接建立后如果长时间没有客户端请求,那么超过8个小时后连接会自动断开,这个时间由wait_timeout参数控制。这个时候需要重连才能继续访问MySQL。

有时候我们会发现MySQL占用内存涨的特别快,这是因为MySQL在执行过程中临时使用的内存是管理在长连接对象中的,这些内存占用在连接断开的时候才会重置。所以长连接在运行过程中可能会因为占用内存过大而被系统杀掉,从现象看就是MySQL服务重启了。有以下两种解决方案:

  • 定期断开长连接,或者执行完一个占用内存比较大的查询后、断开连接,之后的请求再重连;
  • 也可以通过执行mysql_reset_connection命令重置连接,他会将连接重置为连接刚刚建立时的状态(MySQL5.7及以上)。

查询缓存

MySQL在拿到一个查询请求之后,会首先到查询缓存中查看是否有这条查询语句的缓存。缓存时一个K-V结构,K就是这条语句,V是具体的查询结果。如果找到了缓存那么直接返回,否则在进行具体查询,并将结果更新到查询缓存中。

但是在MySQL8之后已经将查询缓存的功能整体移除了,因为这是一种弊大于利的功能,只要对这张表的任何数据有更新操作,那么这张表所涉及的所有查询缓存都会失效。当然一些不经常修改系统变量之类的表仍适合使用查询缓存功能,总体来说弊大于利。

分析器

如果没有命中查询缓存,接下来就会轮到分析器工作。

首先经过词法分析,它会识别出SQL中的字符串分别代表什么,比如select表示查询,id代表主键列等;然后进入语法分析,判断SQL语句是否符合语法标准,如果语法不对,会报出You have an error in your SQL syntax的错误。

优化器

优化器会选择使用哪个索引,当有多表联合查询的时候、决定各个表的连接顺序。

执行器

真正执行的地方,最终扫描行数可以在rows_examined看到

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

相关文章:

  • Linux命令---设备管理
  • 前端入门:HTML5+CSS3+JAAVASCRIPT
  • 【头歌实验】课外作业一:开通ECS及使用Linux命令
  • CMSIS-RTOS2 RTX5移植到GD32L233
  • [网络原理] 网络中的基本概念
  • BeanPostProcessor原理分析
  • 人工智能和网络安全,应该如何选择?
  • Flink预加载分区维表,实时更新配置信息
  • 大数据现在找工作难么
  • 【Linux】学会这些基本指令来上手Linux吧
  • 【沐风老师】3DMAX交通流插件TrafficFlow使用方法详解
  • c#实现视频的批量剪辑
  • 小白怎么系统的自学计算机科学和黑客技术?
  • scheduler 的使用实验对比和总结(PyTorch)
  • vue2 虚拟列表(优化版)
  • 从应用层到MCU,看Windows处理键盘输入 [1.在应用层调试Notepad.exe (按键消费者)]
  • 什么是大数据?大数据能做什么
  • Git 和 GitHub 超入门指南(四)
  • Java 响应式编程 Reactor 框架
  • Hazel引擎学习(十一)
  • 深度学习(22):如何判断训练过程中深度学习模型损失值不再下降
  • 一个比较全面的C#公共帮助类
  • 人脸识别经典网络-MTCNN(含Python源码实现)
  • OpenCV入门(十八)快速学会OpenCV 17 直线检测
  • nginx快速入门.跟学B站nginx一小时精讲课程笔记
  • 内存泄漏定位工具之 valgrind
  • Django(一)安装
  • 11从零开始学Java之如何正确地定义变量?
  • 51单片机之喝水提醒器
  • 扒一扒抖音是如何做线程优化的