关于mysql:Mysql结构和运行流程

9次阅读

共计 2069 个字符,预计需要花费 6 分钟才能阅读完成。

Mysql 构造和运行流程

Mysql 构造

简略版本构造

略微细一点的构造

MySQL = 客户端 + 服务端
    客户端 = Connection(语言连接器例如:PHP-pdo,MySQLi)
    服务端 = SQL 层 + 存储引擎层
        SQL 层 = 链接 / 线程解决 + 查问缓存 + 分析器 + 优化器
        存储引擎 = InnoDB + MariaDB + .....

Connection:这一块其实次要是其余语言的连贯,并不属于 MySQL 自身;次要是其余语言对于 MySQL 的连贯操作的工具比方 PHP 中的:pdo,mysqli 或者 Navicat for MySQL

SQL 层:性能次要包含权限判断,SQL 解析性能和查问缓存解决等。

  1. 链接 / 线程解决:客户端通过 连贯 / 线程层 来连贯 MySQL 数据库,连贯 / 线程层次要用来解决客户端的申请、身份验证和数据库安全性验证等。
  2. 查问缓存和查问分析器是 SQL 层的外围局部,其中次要波及查问的解析、优化、缓存、以及所有内置的函数,存储过程,触发器,视图等性能。
  3. 优化器次要负责存储和获取所有存储在 MySQL 中的数据。

运行流程


这里将执行流程大体分为:启动 -> 连贯 -> 解决 -> 后果解决

(上面程序标号对应上图中的步骤号)

启动

  • 1)通过命令 net start mysql(windows) / service mysql start(linux)启动 MySQL 服务
  • 2)调用初始模块;初始化模块就是在数据库启动的时候,对整个数据库做的一些初始化操作,比方各种零碎环境变量的初始化,各种缓存,存储引擎初始化设置等。

连贯

  • 3)用户发送一条 SQL,这个时候会被网络交互模块监听到用户的操作申请,传递给 连贯治理模块
  • 4)接管到申请转发到 进 / 线程连贯模块
  • 5)调用 用户模块 来进行权限检测(拜访数据库的权限),如果监测失败,间接返回,不往下走了。
  • 6)通过检测之后就会去 线程连接池 中查找闲暇的被缓存的 线程连贯 , 如果找到就返回,如果没找到就从新创立一个。 客户端申请 对接,如果没找到,则创立一个新的 线程连贯
  • 7)将 线程连贯 客户端申请 对接后返回给下一步

解决

  • 8)在用户权限校验胜利并且取得新的连接池之后就会去 命令散发器 ,判断命令的类型如果是 select 就会去拜访 查问缓存,如果没有就会往下执行;
  • 9)如果是 select,并且开启 查问缓存 之后就会去缓存中查问是否有与之相匹配的 SQL, 如果有就会校验用户拜访该数据的权限; 通过就返回, 不通过就会返回错误信息. 如果数据没有就会往下执行;
  • 10)会记录过程中的 SQL 操作过程到日志文件中 (感觉其实记录日志应该是在查问缓存模块之前,只有有 sql 操作进入 命令散发器,就会进行日志记录)
  • 11)在第 8,9 步 没有满足相应条件之后往下执行进入 命令解析器, 通过词法剖析, 语法分析后生成解析树
  • 12)依据操作转到对应的模块解决(预处理阶段),依据 SQL 抉择执行的模块
  • 13)模块收到申请后,通过 访问控制模块 查看所连贯的用户是否有拜访指标表和指标字段的权限(是指拜访这些数据的权限)
  • 14)有权限 表治理模块 先查看 table cache 中是否存在,有则间接对应的表和获取锁,否则从新关上表文件
  • 15)依据表的 ENGINE 数据,获取表的存储引擎类型等信息
  • 16)通过接口调用对应的存储引擎解决
  • 17)返回查问之后数据内容

用户模块:次要性能是用于管制用户登入连贯的权限和用户受权治理。

访问控制模块:次要用于监控用户的每一个操作。访问控制模块实现的性能就是依据用户模块中不同的用户受权,以及依据其数据库的各种束缚来管制用户对数据的拜访。用户模块和访问控制模块联合起来,就组成了 MySQL 数据库的权限治理性能。

查问优化器:这个模块次要是讲客户端发送的查问申请,在之前算法的根底上剖析,计算出一个最优的查问策略,优化之后会进步查问拜访的速度,最初依据其最优策略返回查问语句。

表变更治理模块:次要负责实现 DML 和 DDl 的查问,列如,insert,update,delete,create table,alter table 等语句解决。

表保护模块:次要用于检测表的状态,剖析,优化表构造,以及修复表。

复制模块:复制模块分为 Master 模块和 Slave 模块两局部。Master 模块次要负责复制环境中读取 Master 端的 binary 日志,以及 Slave 端的 I / O 线程交互等工作。

状态模块:在客户端申请零碎状态的时候,零碎状态模块次要负责将各种状态的数据返回给用户。最罕用的一些查问状态的命令包含 show status,show variable 是等,都是通过这个模块负责返回的。

表治理模块:次要就是保护系统生成的表文件。列如 MyISAM 存储引擎就生成 frm,myd,myi 文件,保护这些文件,江哥哥表构造的信息缓存起来,另外该模块还治理表级别的锁。

存储引擎接口模块:MySQL 实现了其数据库底层存储引擎的插件师治理,将各种数据处理高度抽象画。

后果解决

  1. 命令执行完了之后,将后果集返回给 进 / 线程连贯模块(返回的也能够是相应标识,成功失败)
  2. 进 / 线程连贯模块 进行后续的清理工作,并持续期待申请或断开与客户端的连贯

本文章内容来在通过六星培训的解说后依据课件进行整顿和公布的。

正文完
 0