简述MySql核心组件 - 极悦
首页 课程 师资 教程 报名

简述MySql核心组件

  • 2021-01-04 17:54:40
  • 1550次 极悦

由于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大专业测评方法

代码逻辑 吸收能力 技术学习能力 综合素质

先测评确定适合在学习

在线申请免费测试名额
价值1998元实验班免费学
姓名
手机
提交