一文搞懂MySQL运行机制原理

 更新时间:2022年09月30日 08:35:30   作者:1个俗人​​​​​​​  
这篇文章主要介绍了一文搞懂MySQL运行机制原理,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下

前言

前文我们了解了MySQL采用客户端/服务器架构,用户通过客户端程序发送增删改查需求,服务器程序收到请求后处理,并且把处理结果返回给客户端。这篇文章主要看下MySQL服务端是如何处理客户端的请求,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

MySQL服务器体系架构

MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层。

网络连接层

客户端连接器:提供与MySQL服务器建立的支持。

服务层

主要包含系统管理和控制工具、连接池、SQL接口、解析器、查询优化器和缓存六个部分。

  • 1) 连接池:存储和管理客户端与数据库的连接。
  • 2) 系统管理和控制工具:集群、备份、安全管理。
  • 3) SQL接口:接受客户端发送的各种SQL命令并返回查询结果。
  • 4) 解析器:解析SQL,生成一颗解析树,验证SQL是否合法。
  • 5) 查询优化器:将解析树转化成执行计划,与存储引擎进行交互。
  • 6) 缓存:各种缓存,比如表、记录、权限等等,缓存有命中查询结果直接返回。

存储引擎层

负责MySQL中数据的存储与提取,与底层系统文件进行交互,可插拔,常见的两类:MyISAM和InnoDB。

系统文件层

负责将数据库的数据和日志存储在文件系统之上,并完成与存储引擎的交互,比如日志、配置文件等等。

服务器处理客户端请求

客户端可以向服务器发送增删改查等各类请求,我们来看一下服务器是如何处理客户端发送的请求。

连接管理

客户端与服务器进程建立连接,每当有一个客户端进程连接到服务器进程时,服务器进程都会创建一个线程来专门处理与这个客户端的交互,当该客户端退出时会与服务器断开连接,服务器会把线程缓存起来。

解析与优化

查询缓存

如果两个查询请求在任何字符上的不同都会导致缓存不命中。请求中包含某些系统函数、用户自定义变量和函数、一些系统表也不会被缓存。

只要该表的结构或者数据被修改,则该表的所有高速缓存查询都将无效并删除。

PS:8.0中查询缓存已经删除了

语法解析

如果查询缓存没有命中,就进入查询阶段,服务器先对文本做分析,判断语法是否正确,然后从文本中将要查询的表、各种查询条件都提取出来放到内部使用的一些数据结构上。

算是一个编译过程,涉及词法解析、语法分析、语义分析等阶段。

查询优化

对SQL做优化,生成一个执行计划,表明了应该使用哪些索引进行查询,表之间的连接顺序是怎样的。

我们可以使用Explain来查看某个语句的执行计划。

存储引擎

完成查询优化之后还没有真正去访问真实的数据表,数据的存储和提取操作都封装到了这个模块里。不同存储引擎管理的表具体的存储结构可能不同,采用存取算法也可能不同。

小结

MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层。mysql执行查询的过程如下:

  • 客户端先发送查询语句给服务器
  • 服务器检查缓存,如果存在则返回
  • 进行sql解析,生成解析树,再预处理,生成第二个解析树,最后再经过优化器,生成真正的执行计划
  • 根据执行计划,调用存储引擎的API来执行查询
  • 将结果返回给客户端。

到此这篇关于一文搞懂MySQL运行机制原理的文章就介绍到这了,更多相关MySQL运行机制内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MYSQL开发性能研究之批量插入数据的优化方法

    MYSQL开发性能研究之批量插入数据的优化方法

    在网上也看到过另外的几种方法,比如说预处理SQL,比如说批量提交。那么这些方法的性能到底如何?本文就会对这些方法做一个比较
    2017-07-07
  • MySQL使用LIKE索引是否失效的验证的示例

    MySQL使用LIKE索引是否失效的验证的示例

    LIKE查询可以通过一些方法来使得LIKE查询能够使用索引,本文主要介绍了MySQL使用LIKE索引是否失效的验证的示例,具有一定的参考价值,感兴趣的可以了解一下
    2024-08-08
  • MySQL 行转列详情

    MySQL 行转列详情

    这篇文章主要介绍了MySQL 行转列详情,MySQL 行转列语句不难,具体的详细资料,感兴趣的小伙伴可以参考一下
    2022-01-01
  • MySQL分库分表后路由策略设计详情

    MySQL分库分表后路由策略设计详情

    这篇文章主要介绍了MySQL分库分表后路由策略设计详情,分库分表后设计到的第一个问题就是,如何选择路由key,应该如何对key进行路由
    2022-08-08
  • 教你使用idea连接服务器mysql的步骤

    教你使用idea连接服务器mysql的步骤

    这篇文章主要介绍了如何使用idea连接服务器上的mysql,具体步骤本文给大家介绍的非常详细,需要的朋友可以参考下
    2024-02-02
  • 在SQL中获取一个长字符串中某个字符串出现次数的实现方法

    在SQL中获取一个长字符串中某个字符串出现次数的实现方法

    以下是对在SQL中获取一个长字符串中某个字符串出现次数的实现方法进行了详细的分析介绍,需要的朋友可以参考下
    2013-07-07
  • mysql数据库太大了如何备份与还原

    mysql数据库太大了如何备份与还原

    今天小编就为大家分享一篇关于mysql数据库太大了如何备份与还原,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • mysql数据库查询优化 mysql效率

    mysql数据库查询优化 mysql效率

    MySQL由于它本身的小巧和操作的高效, 在数据库应用中越来越多的被采用.我在开发一个P2P应用的时候曾经使用MySQL来保存P2P节点,由于P2P的应用中,结点数动辄上万个,而且节点变化频繁,因此一定要保持查询和插入的高效.以下是我在使用过程中做的提高效率的三个有效的尝试. 1. 使用statement进行绑定查询 2. 随机的获取记录 3. 使用连接池管理连接.
    2008-01-01
  • mysql 5.0.45 (修改)拒绝服务漏洞

    mysql 5.0.45 (修改)拒绝服务漏洞

    mysql 5.0.45 (修改)拒绝服务漏洞的方法,追求安全的朋友可以参考下。
    2010-07-07
  • 安装的mysql中没有my.ini文件的解决方法

    安装的mysql中没有my.ini文件的解决方法

    本文主要介绍了安装的mysql中没有my.ini文件的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03

最新评论