本文主要是介绍Mysql基础(1) - 基础架构,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
MySQL 分为 Server 层和存储引擎层
- Server 层包括连接器、查询缓存、分析器、优化器、执行器等,涵盖 MySQL 的大多数核心服务功能,以及所有的内置函数(如日期、时间、数学和加密函数等),所有跨存储引擎的功能都在这一层实现,比如存储过程、触发器、视图等。
- 存储引擎层负责数据的存储和提取。其架构模式是插件式的,支持 InnoDB、MyISAM、Memory 等多个存储引擎。现在最常用的存储引擎是 InnoDB,它从 MySQL 5.5.5 版本开始成为了默认存储引擎。
Server 层
- 连接器负责跟客户端建立连接,获取权限,维持和管理连接。mysql执行中一些数据绑定在连接对象中,因为长连接长时间不断开导致内存占用太多。(1)定期断开长连接。使用一段时间,或者程序里面判断执行过一个占用内存的大查询后,断开连接,之后要查询再重连。(2)如果MySQL 5.7 或更新版本,可以在每次执行一个比较大的操作后,通过执行 mysql_reset_connection 来重新初始化连接资源。这个过程不需要重连和重新做权限验证,但是会将连接恢复到刚刚创建完时的状态。
- 查询缓存,之前执行过的语句及其结果可能会以 key-value 对的形式,被直接缓存在内存中。建议不要使用查询缓存,(1)缓存需要语句完全相等,包括参数。(2)查询缓存的失效非常频繁,只要有对一个表的更新,这个表上所有的查询缓存都会被清空。 因此,只有在表更新频率不高,查询语句完全一致的情况下,可以手动开启缓存,其他一律关闭。 注意:
mysql8之后,取消了缓存功能。 - 分析器先会做“词法分析”,再做“语法分析”。
- 优化器是在表里面有多个索引的时候,决定使用哪个索引;或者在一个语句有多表关联(join)的时候,决定各个表的连接顺序。一条 SQL 语句可能有不同的执行逻辑(或者顺执行顺序),而优化器就是选择最优的执行顺序。
- 执行器,Mysql执行的流程包括分析器阶段的词法分析和语法分析,优化器阶段的索引和连接顺序优化,最后由执行器开始执行。 分析器解释出你要做什么; 优化器解释出你需要该怎么做; 执行器负责执行。到了执行的时候才会进入到数据库引擎,然后执行器也是通过调用数据库引擎的API来进行数据操作的。
这篇关于Mysql基础(1) - 基础架构的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!