bitsCN.com
学习完词法分析和语法分析后,开始进入Mysql源码的正式学习之旅了。这么多模块,肿么入手呢?!还好从网上搜到了一个模块划分,以后就尽可能根据这个模块划分一步一步的跟踪源码,揭开Mysql的面纱。
<script></script>
我们从上至下来看各个模块的划分,首先客户端发送请求与服务器连接,通过connection manager模块,连接管理模块会调用Thread Manager模块,即线程管理模块,这里会为一个连接创建一个新的线程,专门为这个连接服务,这就保证了每个连接都有一个独立的线程为之工作,当然连接数一般也会有个限制,不然无限制的创建新的线程,操作系统也顶不住啊。接着进入了User Module,用户模块,这个模块应该是身份识别认证阶段,说白了就是检查用户名密码,当然应该还包括权限检查(只有自主访问控制,Mysql不像Oracle,不支持role,更不用说label了。这就是简约而不简单吧,^_^)。
上面的三个模块就是登录过程中必须经历的阶段。connection manager为客户端和服务器创建连接,thread manager为新建的连接分配一个独立的线程,user Module进行身份认证。oh yeah~~
接着进入Commander Dispatcher模块,命令分发模块,大概就是一个switch case的过程,根据不同的命令,进行不同的操作。这个模块又会间接关联到Query Cache模块和Logging Module,即查询缓存模块和日志模块。Query Cache模块个人感觉至少包含结果集缓存模块,至于有木有执行计划缓存,这个就不清楚了,还需要进入源码慢慢看来。Logging Module就是传说中的日志了,日志包括redo和undo两方面吧,日志系统是一个database必备的,是实现事务特性的重要手段,而事务便是database和file system的根本区别,不要小瞧了Logging Module啊!!
命令分发模块,根据命令的性质,将命令分给不同的子模块。SELECT分配给Optimizer即优化模块,一条select语句最重要的就是执行计划了,一个好的执行计划比一个坏的执行计划不知道要快多少倍,这就是为什么我们要建立索引,其实在经常查询的列上建立二级索引,就是为了改变执行计划,让执行计划可以选择二级索引,而抛弃聚簇索引(当然不是完全抛弃,聚簇索引是根本)。UPDATE、INSERT、DELETE交给Table Modification Module,不看也知道,这个模块主要是处理数据更新了(这里所说的更新是指数据的改变,即UID)。Repairs分配给了Table Maintenance Module,字面意义是说表维护模块,我OUT了,默认表坏了,支持修复?是何种坏了?不太了解啊…。Replication分配给了Replication Module,就是复制模块。最后一个是Status分配给了Status Reporting Module,这个我貌似接触过,是不是所谓的那些动态试图?比如查看系统当前状态下的锁资源的占用情况等,这个模块应该是性能分析者居家旅行必备的模块吧,通过这个模块可能很快找到系统性能的瓶颈。
上面的模块又统一走到Access Control Module,访问控制模块啊,原来上面所说的User Module不包含访问控制…,这个访问控制就是简单的DAC,即检查用户是否对要访问的对象具有增、删、改、查的权限。接着进入Table Manager模块,因为Mysql支持不同的存储引擎,而这个模块是个统一的模块,个人感觉这个应该是表的字典对象管理模块,即表的一些元数据,比如这个表包含哪些列啊,各个列的类型,表的创建者,创建日期,表的存储引擎之类的信息。最下面是Abstract Storage Engine Module,即抽象存储引擎模块,Mysql的保持这么多存储引擎同时在服务器中,是通过一个handler抽象类实现的(不知道有木有抽象类的概念,小弟C++、JAVA丢了很久了…),每个存储引擎按照规定的接口,实现一个具体的handler类,然后再调用的时候,根据上面的Table Manager模块中的存储引擎的信息,选择对应的handler类进行相应表的物理操作。
看了这个模块图,感觉思路清晰了很多。下面就一步一步的学习每个模块,当然这些模块之间也是一个执行流程顺序执行的过程。今天就写到这了,下次开始学习第一个模块:Connection Manager
PS. 貌似最近没这么忙了,加班加了好几个月终于算是稍微轻松了一点。以后把更多的业余时间放在读书学习上。
PS again. 每天下班脑子都一锅粥了,回来写点博客权当放松啦,标题的八度空间是JAY的专辑名啦,借此来比喻Mysql的各个模块^_^
摘自 心中无码 bitsCN.com

InnoDB使用redologs和undologs确保数据一致性和可靠性。1.redologs记录数据页修改,确保崩溃恢复和事务持久性。2.undologs记录数据原始值,支持事务回滚和MVCC。

EXPLAIN命令的关键指标包括type、key、rows和Extra。1)type反映查询的访问类型,值越高效率越高,如const优于ALL。2)key显示使用的索引,NULL表示无索引。3)rows预估扫描行数,影响查询性能。4)Extra提供额外信息,如Usingfilesort提示需要优化。

Usingtemporary在MySQL查询中表示需要创建临时表,常见于使用DISTINCT、GROUPBY或非索引列的ORDERBY。可以通过优化索引和重写查询避免其出现,提升查询性能。具体来说,Usingtemporary出现在EXPLAIN输出中时,意味着MySQL需要创建临时表来处理查询。这通常发生在以下情况:1)使用DISTINCT或GROUPBY时进行去重或分组;2)ORDERBY包含非索引列时进行排序;3)使用复杂的子查询或联接操作。优化方法包括:1)为ORDERBY和GROUPB

MySQL/InnoDB支持四种事务隔离级别:ReadUncommitted、ReadCommitted、RepeatableRead和Serializable。1.ReadUncommitted允许读取未提交数据,可能导致脏读。2.ReadCommitted避免脏读,但可能发生不可重复读。3.RepeatableRead是默认级别,避免脏读和不可重复读,但可能发生幻读。4.Serializable避免所有并发问题,但降低并发性。选择合适的隔离级别需平衡数据一致性和性能需求。

MySQL适合Web应用和内容管理系统,因其开源、高性能和易用性而受欢迎。1)与PostgreSQL相比,MySQL在简单查询和高并发读操作上表现更好。2)相较Oracle,MySQL因开源和低成本更受中小企业青睐。3)对比MicrosoftSQLServer,MySQL更适合跨平台应用。4)与MongoDB不同,MySQL更适用于结构化数据和事务处理。

MySQL索引基数对查询性能有显着影响:1.高基数索引能更有效地缩小数据范围,提高查询效率;2.低基数索引可能导致全表扫描,降低查询性能;3.在联合索引中,应将高基数列放在前面以优化查询。

MySQL学习路径包括基础知识、核心概念、使用示例和优化技巧。1)了解表、行、列、SQL查询等基础概念。2)学习MySQL的定义、工作原理和优势。3)掌握基本CRUD操作和高级用法,如索引和存储过程。4)熟悉常见错误调试和性能优化建议,如合理使用索引和优化查询。通过这些步骤,你将全面掌握MySQL的使用和优化。

MySQL在现实世界的应用包括基础数据库设计和复杂查询优化。1)基本用法:用于存储和管理用户数据,如插入、查询、更新和删除用户信息。2)高级用法:处理复杂业务逻辑,如电子商务平台的订单和库存管理。3)性能优化:通过合理使用索引、分区表和查询缓存来提升性能。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

SublimeText3汉化版
中文版,非常好用

Dreamweaver Mac版
视觉化网页开发工具

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

Atom编辑器mac版下载
最流行的的开源编辑器