MySQL架构初步了解

MySQL架构初步了解

​ 最近一段时间一直没有更新博客,虽然一直在学习新东西,但是没有精力和时间(借口)将学习到的东西整理成博客。见到朋友圈一位大佬一直在不间断的更新博客,还是挺佩服的,只有自己尝试过后才知道坚持输出到底是一件多么花费毅力的事。后面还是慢慢来吧,慢慢把自己学习的一些东西整理一下。

​ 本次算是MySQL的继续学习,因为后续的学习离不开MySQL架构,所以这篇博客算是一篇前置博客。介绍一下MySQL的架构和每个组件的作用。后续就学习MySQL中比较重要的两个日志。

​ MySQL的架构大致可以分为两个部分,Server层和存储引擎层两部分。

​ Server层包括连接器、查询缓存、分析器、优化器、执行器等,涵盖MySQL的大多数核心服务功能,以及所有的内置函数(如日期、时间、数学和加密函数等),所有跨存储引擎的功能都在这一层实现,比如存储过程、触发器、视图等。

​ 存储引擎层负责数据的存储和提取。其架构模式是插件式的,支持InnoDB、MyISAM、Memory等多个存储引擎。现在最常用的存储引擎是InnoDB,它从MySQL 5.5.5版本开始成为了默认存储引擎。

​ 还有一个文件系统,但是因为文件系统部分属于操作系统底层,所以这里不再详细描述。整体架构图如下图所示。

MySQL架构初步了解_第1张图片

​ 这里的架构图来自于MySQL官方文档,地址如下:MySQL架构图

​ 还有一个林晓斌大佬的架构图。这个图可能看的清楚一些,同时能够知道SQL到底是如何执行的。

MySQL架构初步了解_第2张图片

​ 上面的图可以看出一个查询SQL的执行流程,作为开发人员了解这些基本已经够用了,后续如果需要可以自己深入学习一下。

​ 前置博客,没必要写太多。最后就放上一些查资料中发现写的不错的博客,这里也不再辨别是抄的还是自己写的了。

​ MySQL体系结构详解

​ 就这样吧,结束。

你可能感兴趣的:(mysql)