最上层是一些客户端和连接服务,包含本地sock通信和大多数基于客户端/服务端工具实现的类似于tcp/ip的通信。主要完成一些类似于连接处理、授权认证、及相关的安全方案。在该层上引入了线程池的概念,为通过认证安全接入的客户端提供线程。同样在该层上可以实现基于SSL的安全链接。服务器也会为安全接入的每个客户端验证它所具有的操作权限。
2.服务层1.Management Serveices & Utilities:系统管理和控制工具
2.SQL Interface: SQL接口
接受用户的SQL命令,并且返回用户需要查询的结果。比如select from就是调用SQL Interface,看最开始传过来是什么,比如存储过程.视图.sql语句找到对应的接口
3.Parser: 解析器
SQL命令传递到解析器的时候会被解析器验证和解析,检验代码的正确性
4.Optimizer: 查询优化器
SQL语句在查询之前会使用查询优化器对查询进行优化。
用一个例子就可以理解: select uid,name from user where gender= 1;
优化器来决定先投影还是先过滤。
5.Cache和Buffer: 查询缓存
如果查询缓存有命中的查询结果,查询语句就可以直接去查询缓存中取数据。
这个缓存机制是由一系列小缓存组成的。比如表缓存,记录缓存,key缓存,权限缓存等
缓存是负责读,缓冲负责写。
如果查询发现缓存有对应的数据直接返回回去
存储引擎层,存储引擎真正的负责了MySQL中数据的存储和提取,服务器通过API与存储引擎进行通信。不同的存储引擎具有的功能不同,这样我们可以根据自己的实际需要进行选取。mysql5.5版本以后默认是InnoDB,在5.5版本之前都是MyISAM
二.MySQL存储引擎1.查看存储引擎命令
// 查看存储引擎命令 show engines;
InnoDB 注释 supports transactions -- 支持事务 row-level locking -- 支持行级锁 foreign keys -- 支持外键
2.查看默认存储引擎
// 查看默认存储引擎 show variables like '%storage_engine%';三.存储引擎丶特性
重要区别,锁机制,事务,外键
InnoDB: 所有引擎只有InnoDB支持外键,锁机制是行锁以及支持事务,mysql默认事务隔离级别是可重复读
MyISAM:不支持事务以及外键,锁机制相对于是表锁,范围更大不利于高并发



