由于MySQL的组件众多,很难在有限的篇幅解释清楚所有的MySQL组件,所以这里我们就只讨论一些相对而言比较重要的MySQL核心组件。
一、Service层
1.客户端连接器:也称之为mysql应用层。主要负责:
连接处理:当客户端请求上来mysql会从线程池分配一个线程来与客户端连接,如果连接处于空闲状态, wait_timeout参数决定断开时间;
-用户鉴权:是通过用户名,客户端地址,密码的方式来鉴权用户;
-安全管理:mysql通过连接的权限来控制连接可以执行哪些操作;
-查询缓存:之前执行过的语句与结果是以K-V方式保存在查询缓存中,查询请求如果命中-直接返回,查询结束。查询缓存失效非常频繁, 只要对一张表进行更新,那么它所对应的的查询缓存都会被清空。query_cache_type参数来设置是否使用查询缓存,8.0以后的版本直接废弃查询缓存。
2.分析器/解析器:如果没有命中查询缓存,将会进入分析器。先开始做词法分析解析出表名,函数,关键字等,然后开始校验语法分析,校验语法的正确性,我们常看到的:You have an error in your SQL syntax...的错误提示就是从这里返回的。一般语法错误会提示第一个出现错误的位置,依次类推。
3.优化器:经过分析器,SQL有多张表关联或者有多个索引的时候,优化器是根据索引来决定表的顺序与条件顺序。你写的SQL语句没有强行设置执行顺序的话,可能不是你想要的条件执行顺序,后面我会专门来说优化器对索引的选择算法。
4.执行器:经过优化的SQL重写以后,执行器会先判断线程有没有数据的读写权限,如果有将打开表继续执行。执行器会根据不同存储引擎接口来调用api实现,根据索引规则来对表进行扫描,返回结果。如果表或者列不存在就会看到:Table doesn't exist,Unknown column where clause这样的提示。
二、MySql管理系统(MySQL Management Server & utilities)
MySql管理系统提供了丰富的数据库管理功能,例如:数据库备份和恢复,数据库安全管理与权限管理,数据库复制管理,集群管理,数据库元数据管理,分库分别管理等。
存储引擎:一种管理物理数据和位置的插件类组件,负责执行sql语句并从磁盘文件中获取数据。
磁盘文件:包括redolog、undolog、binlog、errorlog、querylog、slowlog、data、index等。
三、核心子系统:
1.基本函数库子系统:在所有mysql子系统之间共享的一组通用函数。
2.进程,线程和资源管理子系统:基于线程资源的管理服务器体系结构。
3.缓存和缓冲区管理子系统:提高查询速度,减少IO次数的检索方式。私有会话级别与实例共享级别。
4.网络连接与通信管理系统:维护这全部的会话连接与通信。
5.日志管理子系统:管理所有的mysql日志,数据日志,操作日志,慢查询日志,访问日志等。
6.数据和存储管理子系统:管理数据文件与存储方式,存储格式,存储位置。
总的来说,一个数据库的核心都是大同小异的,只要我们掌握了MySQL核心组件,对于我们学习其他数据库也是有很大帮助的。在本站的MySQL教程中,对于MySQL的一些次要的组件也有很详细的介绍,对于我们了解和使用MySQL数据库有很大的帮助。
你适合学Java吗?4大专业测评方法
代码逻辑 吸收能力 技术学习能力 综合素质
先测评确定适合在学习