MySQL架构的简单介绍

行业解决方案、产品招募中!想赚钱就来传!>>> MySQL架构的简单介绍

MySQL的逻辑架构介绍

MYSQL分为四层

连接层服务层引擎层存储层

MySQL架构的简单介绍

连接层

主要完成一些类似于连接处理、授权认证、及相关的安全方案。在该层上引入了线程池的概念,为通过认证安全接入的客户端提供线程。

服务层

  1. Management Serveices & Utilities: 系统管理和控制工具

  2. SQL Interface: SQL接口 接受用户的SQL命令,并且返回用户需要查询的结果。比如select from ...就是调用SQL Interface

  3. Parser: 解析器 SQL命令传递到解析器的时候会被解析器验证和解析。

  4. Optimizer: 查询优化器 SQL语句在查询之前会使用查询优化器对查询语句进行优化。

  5. Cache和Buffer: 查询缓存

    先在缓存中查询数据,在缓存中查到数据直接查询结果;缓存中查不到数据,再去数据库中查数据 这个缓存机制是由一系列小缓存组成的。比如表缓存,记录缓存,key缓存,权限缓存等

引擎层

存储引擎层,包含有各种存储引擎。存储引擎真正的负责了MySQL中数据的存储和提取,服务器通过API与存储引擎进行通信。不同的存储引擎具有的功能不同,这样我们可以根据自己的实际需要进行选取。

存储层

数据存储层,主要是将数据存储在运行于裸设备的文件系统之上,并完成与存储引擎的交互。

存储引擎

引擎层中有多种引擎

查询命令

查询存储引擎:show engines;

MySQL架构的简单介绍

这张表展示了存储引擎的名字,介绍信息,是否支持事务等信息

查看MySQL默认使用的引擎:showvariables like '%storage_engine%';

MySQL架构的简单介绍

各个引擎的简介

  1. InnoDB存储引擎 InnoDBMySQL的默认事务型引擎,用来处理大量的短期(short-lived)事务。除非有非常特别的原因需要使用其他的存储引擎,否则应该优先考虑InnoDB引擎。

  2. MyISAM存储引擎 MyISAM提供了大量的特性,包括全文索引、压缩、空间函数(GIS)等,但MyISAM不支持事务和行级锁,缺陷就是崩溃后无法安全恢复。

  3. Archive引擎 Archive档案存储引擎只支持INSERTSELECT操作,在MySQL5.1之前不支持索引。 Archive表适合日志和数据采集类应用。

  4. Blackhole引擎 Blackhole引擎没有实现任何存储机制,它会丢弃所有插入的数据,不做任何保存。但服务器会记录Blackhole表的日志,所以可以用于复制数据到备库,或者简单地记录到日志。但这种应用方式会碰到很多问题,因此并不推荐。

  5. CSV引擎 CSV引擎可以将普通的CSV文件作为MySQL的表来处理,但不支持索引。 CSV引擎可以作为一种数据交换的机制,非常有用。 CSV存储的数据直接可以在操作系统里,用文本编辑器,或者excel读取。

  6. Memory引擎 如果需要快速地访问数据,并且这些数据不会被修改,重启以后丢失也没有关系,那么使用Memory表是非常有用。Memory至少比MyISAM要快一个数量级。

  7. Federated引擎 Federated引擎是访问其他MySQL服务器的一个代理,尽管该引擎看起来提供了一种很好的跨服务器的灵活性,但也经常带来问题,因此默认是禁用的。

SQL的执行周期

目标:了解一个简单的select查询语句的执行情况

  1. 设置开启查询记录和缓存查询

    修改MySQL的配置文件,在配置文件中添加一条profiling=1;后重启MySQL服务

    MySQL中执行set query_cache_type=1

  2. 执行一条sql语句,例如:SELECT * FROM userWHEREname='tom';

  3. 获取查询记录SHOW PROFILES;,并记下你执行的这条sql的Query_ID

    MySQL架构的简单介绍

  4. 获取指定sql的执行周期show profile cpu,block io for query 6;(这里的Query_ID根据自己的情况而定)

    MySQL架构的简单介绍