MySQL架构
MySQL采用的是C/S架构,我们在使用MySQL的时候,都是以客户端的身份,发送请求连接到运行服务端的MySQL守护进程,而MySQL服务器端则根据我们的请求进行处理并把处理后的结果返回给我们
1. 连接管理器
连接管理器的作用是管理和维持所有MySQL
客户端的请求连接,当我们向MySQL发起请求时,连接管理器会负责创建连接并校验用户的权限。
对于已经建立的连接,如果没有太久没有发送请求,连接管理器会自动断开连接,我们可以通过设置变量wait_timeout
决定多久断开不活跃的连接。
2. 查询缓存
当我们与连接器建立连接后,如果我们执行的是SELECT
语句,那么连接器会先从查询缓存
中查询,看看之前是否执行过这条语句,如果没有再往走,如果有则判断相应的权限,符合权限,则直接返回结果。
查询缓存
其实是把查询语句当作一个key
,查询结果当用value
,建立起来的key-value
缓存结构。
不过,当数据表的数据发生变化时,缓存会被删除。
在MySQL 8.0
版本中已经将查询缓存的整块功能删掉了
3. 解析器
当查询缓存中没有,则需要执行真正的SQL,这时候解析器进行词法分析,对SQL语句拆解,拆解后分析判断是否符合MySQL语法规则
4. 查询优化器
经过分析器的词法和语法分析,MySQL
服务器已经知道我们要查询什么了,不过,在开始查询前,还要交由查询优化器进行优化。
在优化的过程,优化器会根据SQL
语句的查询条件决定使用哪一个索引,如果有连接(join),会决定表的查询顺序,最终会根据优化的结果生成一个执行计划交由下面的执行器去执行。
5. 执行器
SQL语句在经过查询优化器的优化后,接下来就交由执行器开始执行,不过执行器在开始执行前,会判断用户对相应的数据表是否有权限。
6. 存储引擎
存储引擎
,也叫做表类型
,其具体作用便是决定一个数据表怎么处理和存储表中的数据,MySQL支持多种不同的存储引擎,而且存储引擎被设计为可插拔式的,在同一个数据库中,不同的数据表可以使用不同的存储引擎。
Innodb
是MySQL
的默认存储引擎,也是常用的存储引擎,另外比较常用的存储引擎还有MyISAM
和Momery
。