MySQL知识(一)之MySQL架构

152 阅读2分钟

本篇文章参考自juejin.cn/post/685003…

MySQL架构图 序言:

数据库是由一个个文件组成(一般来说都是二进制的文件)的,要对这些文件执行诸如SELECT、INSERT、UPDATE和DELETE之类的数据库操作是不能通过简单的操作文件来更改数据库的内容,需要通过数据库实例来完成对数据库的操作。

MySQL组成成分

  • 连接池组件
  • 管理服务和工具组件
  • SQL接口组件
  • 查询分析器组件
  • 优化器组件
  • 缓冲(Cache)组件
  • 插件式存储引擎
  • 物理文件

可以将其浓缩为:

  • 连接层:一些客户端和连接服务。主要完成一些类似于连接处理、授权认证、及相关的安全方案。
  • 服务层: 主要完成大部分的核心服务功能, 包括查询解析、分析、优化、缓存、以及所有的内置函数,所有跨存储引擎的功能也都在这一层实现,包括触发器、存储过程、视图等
  • 引擎层:存储引擎真正的负责了MySQL中数据的存储和提取,服务器通过API与存储引擎进行通信。
  • 存储层:数据存储层(数据文件和日志),主要是将数据存储在运行于该设备的文件系统之上,并完成与存储引擎的交互
涉及到的问题:
描述 MySQL 的具体查询流程一条SQL语句在MySQL中如何执行的
解答:
客户端请求 ---> 连接池(验证用户身份,给予权限) ---> 查询缓存(存在缓存则直接返回,不存在则执行后续操作) ---> 分析器(对SQL进行词法分析和语法分析操作) ---> 优化器(主要对执行的sql优化选择最优的执行方案方法) ---> 执行器(执行时会先看用户是否有执行权限,有才去使用这个引擎提供的接口) ---> 去引擎层获取数据返回(如果开启查询缓存则会缓存查询结果)

当客户端发起查询请求,客户端先尝试与数据库连接池建立连接,当用户身份验证通过后,查询缓存,若有该数据缓存则直接返回,若不存在,分析器对sql语句进行词法分析和语法分析操作,然后优化器对sql语句进行优化,选择最优的执行方案,然后执行器根据用户是否有执行权限,有则使用这个引擎提供的接口,通过存储引擎获取数据返回(如果开启查询缓存则会缓存查询结果)。