• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

了解 MySQL 体系架构

mysql 搞代码 4年前 (2022-01-09) 19次浏览 已收录 0个评论

mysql视频教程栏目介绍MySQL体系架构

推荐(免费):mysql视频教程

MySQL 体系架构

MySQL 体系架构主要分为两部分:客户端和服务端

客户端

客户端连接器主要负责一些客户端的连接,针对不同的编程语言驱动提供连接服务。

服务端

服务层包括:系统管理和控制工具,连接池,SQL接口,解析器,查询优化器,缓存。

  • 连接池
    负责管理客户端与服务层数据处理的连接,以及对用户执行操作权限的校验。

  • 系统管理和控制工具
    负责备份安全,安全管理,集群管理服务和工具等。

  • SQL接口
    接收客户端 sql命令 ,返回用户需要的结果。如:dml,ddl,存储过程,视图,触发器等命令。

  • 解析器
    词语(关键字)分析,语法分析,接收sql 将其解析,生成解析树,并且语法校验检查。

  • 查询优化器:对生成解析树后并且通过解析器语法后,由优化器选择合适的索引,然后生成执行计划,然后与执行引擎交互。

  • 缓存
    缓存机制是由一系列缓存组合起来的。
    如:表缓存,记录缓存(sql查询结果缓存起来,等下一次相同sql查询

    本文来源gaodai^.ma#com搞#代!码网

    ,从缓存中返回),
    权限缓存,引擎缓存等。如果缓存命中,会直接从缓存中获取数据。

  • 存储引擎层
    负责Mysql 数据的读取和存取,如 InnoDB,MyISAM等。 可插拔式的,可以更换不同的存储引擎。

  • 系统文件层
    如日志,数据文件等。

一条SQL的执行流程

  • 首先客户端进行连接;
  • 其次在server层的连接管理器中验证用户权限等操作;
  • 然后如果是非8.0版本的话会去缓存池中查看当前的sql的缓存,如果有直接返回;
  • 如果缓存中没有则会由解析器语法语义生成解析树;
  • 优化器解析生成执行计划,并且选择合适的索引;
  • 存储引擎调用API接口去查询数据,将查询到的数据更新缓存cache;
  • 最后返回给客户端;

存储引擎层

存储引擎是 MySQL 中具体与文件打交道的子系统,是基于文件系统抽象出来用于mysql和磁盘文件打交道的一个系统;
常用的存储引擎, MyISAM、支持事务的 InnoDB;

  • MySQL 5.6 版本之前,默认的存储引擎都是 MyISAM;
  • 5.6 版本以后默认的存储引擎就是 InnoDB ;

功能对比

  • InnoDB 支持 ACID 的事务 4 个特性,而 MyISAM 不支持;

  • InnoDB 支持 4 种事务隔离级别,默认是可重复读 Repeatable Read 的,MyISAM 不支持;

  • InnoDB 支持 crash 安全恢复,MyISAM 不支持;

  • InnoDB 支持外键,MyISAM 不支持;

  • InnoDB 支持行级别的锁粒度,MyISAM 不支持,只支持表级别的锁粒度;

  • InnoDB 支持 MVCC,MyISAM 不支持;

以上就是了解 MySQL 体系架构的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:了解 MySQL 体系架构

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址