Mysql逻辑架构介绍

1.和其他数据库相比,Mysql有点与众不同,它的架构可在不同场景中应用并发挥良好作用,主要体现在存储引擎的架构上,插件式的存储存储引擎架构将查询处理和其他的系统任务以及数据的存储提取分离,这种架构可以根据不同的实际结合,选择不同的存储引擎。

MySQL Server 使用可插拔存储引擎架构,使存储引擎能够加载到正在运行的 MySQL 服务器中和从中卸载。

①插入存储引擎

在使用存储引擎之前,必须使用该INSTALL PLUGIN语句将存储引擎插件共享库加载到 MySQL 中 。例如,如果EXAMPLE引擎插件被命名example并且共享库被命名 ha_example.so,则使用以下语句加载它:INSTALL PLUGIN example SONAME 'ha_example.so';要安装可插拔存储引擎,插件文件必须位于 MySQL 插件目录中,并且发出INSTALL PLUGIN语句的用户 必须具有INSERT该mysql.plugin表的权限 。共享库必须位于 MySQL 服务器插件目录中,其位置由plugin_dir系统变量给出 。

②拔下存储引擎

要拔掉存储引擎,请使用以下 UNINSTALL PLUGIN语句:UNINSTALL PLUGIN example;如果您拔下现有表所需的存储引擎,这些表将无法访问,但仍存在于磁盘上(如果适用)。在拔下存储引擎之前,请确保没有使用存储引擎的表。

查看你的mysql当前的默认存储引擎:

 MyISAN和InnoDB

 

2.架构介绍

 ①Connectors:指的是不同语言中与SQL的交互。

②Connection Pool:管理缓冲用户连接,线程处理需要缓存的需求。负责监听对MySQL Server的各种请求,接收连接请求,转发所有连接请求到线程管理模块,每一个连接上MySQL Server 的客户端请求都会被分配(或创建)一个连接线程为其单独服务。而连接线程的主要工作就是负责 MySQL Server 与客户端的通信,接受客户端的命令请求,传递 Server 端的结果信息等。线程管理模块则负责管理维护这些连接线程。包括线程的创建,线程的 cache 等。

③Management Serveices & Utilities:系统管理和控制工具。

④SQL Interface:接受用户的SQL命令,并且返回用户需要查询的结果。

⑤Parser:SQL命令传递到解析器的时候会被解析器验证和解析。解析器是由Lex和YACC实现的,是一个很长的脚本。在 MySQL中我们习惯将所有 Client 端发送给 Server 端的命令都称为 query ,在 MySQL Server 里面,连接线程接收到客户端的一个 Query 后,会直接将该 query 传递给专门负责将各种 Query 进行分类然后转发给各个对应的处理模块。

⑥Optimizer:查询优化器:SQL语句在查询之前会使用查询优化器对查询进行优化。就是优化客户端请求query,根据客户端请求的 query 语句,和数据库中的一些统计信息,在一系列算法的基础上进行分析,得出一个最优的策略,告诉后面的程序如何取得这个 query 语句的结果。使用的是“选取-投影-联接”策略进行查询:用一个例子就可以理解: select uid,name from user where gender = 1;这个select 查询先根据where 语句进行选取,而不是先将表全部查询出来以后再进行gender过滤;然后根据uid和name进行属性投影,而不是将属性全部取出以后再进行过滤。最后将这两个查询条件联接起来生成最终查询结果。

⑦Cache和Buffer:查询缓存:主要功能是将客户端提交 给MySQL 的 Select 类 query 请求的返回结果集 cache 到内存中,与该 query 的一个 hash 值 做一个对应。该 query 所取数据的基表发生任何数据的变化之后, MySQL 会自动使该 query 的Cache 失效。在读写比例非常高的应用系统中, Query Cache 对性能的提高是非常显著的。当然它对内存的消耗也是非常大的。如果查询缓存有命中的查询结果,查询语句就可以直接去查询缓存中取数据。这个缓存机制是由一系列小缓存组成的。比如表缓存,记录缓存,key缓存,权限缓存等。

⑧、存储引擎接口:MySQL区别于其他数据库的最重要的特点就是其插件式的表存储引擎。MySQL插件式的存储引擎架构提供了一系列标准的管理和服务支持,这些标准与存储引擎本身无关,可能是每个数据库系统本身都必需的,如SQL分析器和优化器等,而存储引擎是底层物理结构的实现,每个存储引擎开发者都可以按照自己的意愿来进行开发。

注意:存储引擎是基于表的,而不是数据库。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值