怎样阅读InnoDB存储引擎源码
1个回答
2015-03-08 · 知道合伙人互联网行家
关注
展开全部
1.理解MySQL内核对于DBA的重要性;
如果精通内核对于搞数据库的人来说,可以称得上专家。开源数据库的一个最大好处就是可以去读源码,根据自己的需求去进行个性化的开发,毕竟数据库根据业务最基本的也要分为OLTP,OLAP,系统类型的不同,决定了数据很多参数配置以及核心参数的调整也是不一样的。在调整这些参数前,如果不明白实现的原理,只是根据经验值去调整肯定是不行的,参数可以进行调整,比如减少事务表的长度,修改并发时程来减少锁争用等,如果不明白源码里面的实现方式,是没有办法去修改的,调整参数无法完成的个性化需求,可以通过源码去实现。
如果商业数据库比如oracle开放源码,很多的核心原理得到确认,对于深入学习数据库的人来说是个很大的财富,但是这是不可能实现的。mysql的开源化,对于学习mysql来说个很大的宝库,从源码里可以看出各个引擎的实现方式,而这些核心的原理在很多文档里是看不到的。以前pub里有个大牛说过搞开源化的数据库,如果看不懂源码的话,只能在表面上做工作,搞几年下来,基本就是靠运维,部署,高一些读写分离的架构层面的运维工作,不能称其为专家。
作为MYsql DBA,如果精通源码,对于数据库的理解会深入很多,阿里也是从源码上修改,可以支持自己的业务需求。MYSQL这几年的发展也是靠很多的人根据自己的需要写了很多分享行的代码,可见开源化对于mysql的发展起到重要作用。优秀的DBA需要去阅读一些代码,当比较极端的业务需求需要去定制化数据库的一些功能时,可以从源码级别开发设计适合自己的引擎,mysql在引擎方面预留了很多的接口,可以进行个性化开发。目前我能了解的有网易研究院搞的TNT引擎。
2.怎样阅读InnoDB存储引擎源码;
接触mysql也有几年的时间,很多时候都是阅读官方文档,没有真正的从源码去分析和阅读。以前阅读过姜承尧的innodb引擎这本书,是从一些核心原理上进行讲解,非常深入和精彩。要想InnoDB存储引擎源码需要C和C++的基础,自己能够编译一些程序,确保在修改后能够编译成功。我看过InnoDB存储引擎源码,发现里面的源码量非常大,如果要通读一遍的话,需要很长的时间,而且也非常枯燥,读一些就难以坚持下去。
经过一段时间的积累,我感觉是从一些比较常见的问题去阅读,比如读写,异步的实现,lock,latch,mutex的实现方式,还有内存管理的一些链表等去阅读,每天抽时间读一读,就当是消遣一下。对于索引,实务,缓存等内核的源码一点一点的去看,带着理论知识去理解源码,反过来用源码的实现原理来纠正和补充理论知识,在这个过程中可以快速提高自己。
3.说说读完试读章节后您的感想?
这是本非常好的书,可以对着作者以前写的innodb引擎的那本书一起结合看。试读章节主要分享了两章内容:
第一章是概括性的知识,介绍了INNODB存储引擎的历史,如果知道的同学可以直接略过,后续内容对于源码的版本,风格,编译的方式做了一些介绍,主要是给我们一个源码阅读的认识,对于作者分析的源码方法十分认可,按照层次去阅读,这样可以非常容易的去理解。对于我们这些源码分析的初学者来说可以按照作者的建议,进行按部就班的阅读。
第二章介绍了一些INNODB存储引擎的内存管理的实现,基本数据结构,对于后续做个铺垫。以前都是直接学习理论,记住了这些的内容就可以了,现在从源码角度可以去看看实现方式。这些内容如果前期学的比较深入的话,可以大体看看,如果对这些链表,内存管理方法不是很清楚的可以好好读读,毕竟这是深入学习的基础。
这是分析源码方式的卷1,后续期待作者更多精彩的内容分享。让更多的人喜欢并且可以阅读源码,为开源化数据库作出贡献。
如果精通内核对于搞数据库的人来说,可以称得上专家。开源数据库的一个最大好处就是可以去读源码,根据自己的需求去进行个性化的开发,毕竟数据库根据业务最基本的也要分为OLTP,OLAP,系统类型的不同,决定了数据很多参数配置以及核心参数的调整也是不一样的。在调整这些参数前,如果不明白实现的原理,只是根据经验值去调整肯定是不行的,参数可以进行调整,比如减少事务表的长度,修改并发时程来减少锁争用等,如果不明白源码里面的实现方式,是没有办法去修改的,调整参数无法完成的个性化需求,可以通过源码去实现。
如果商业数据库比如oracle开放源码,很多的核心原理得到确认,对于深入学习数据库的人来说是个很大的财富,但是这是不可能实现的。mysql的开源化,对于学习mysql来说个很大的宝库,从源码里可以看出各个引擎的实现方式,而这些核心的原理在很多文档里是看不到的。以前pub里有个大牛说过搞开源化的数据库,如果看不懂源码的话,只能在表面上做工作,搞几年下来,基本就是靠运维,部署,高一些读写分离的架构层面的运维工作,不能称其为专家。
作为MYsql DBA,如果精通源码,对于数据库的理解会深入很多,阿里也是从源码上修改,可以支持自己的业务需求。MYSQL这几年的发展也是靠很多的人根据自己的需要写了很多分享行的代码,可见开源化对于mysql的发展起到重要作用。优秀的DBA需要去阅读一些代码,当比较极端的业务需求需要去定制化数据库的一些功能时,可以从源码级别开发设计适合自己的引擎,mysql在引擎方面预留了很多的接口,可以进行个性化开发。目前我能了解的有网易研究院搞的TNT引擎。
2.怎样阅读InnoDB存储引擎源码;
接触mysql也有几年的时间,很多时候都是阅读官方文档,没有真正的从源码去分析和阅读。以前阅读过姜承尧的innodb引擎这本书,是从一些核心原理上进行讲解,非常深入和精彩。要想InnoDB存储引擎源码需要C和C++的基础,自己能够编译一些程序,确保在修改后能够编译成功。我看过InnoDB存储引擎源码,发现里面的源码量非常大,如果要通读一遍的话,需要很长的时间,而且也非常枯燥,读一些就难以坚持下去。
经过一段时间的积累,我感觉是从一些比较常见的问题去阅读,比如读写,异步的实现,lock,latch,mutex的实现方式,还有内存管理的一些链表等去阅读,每天抽时间读一读,就当是消遣一下。对于索引,实务,缓存等内核的源码一点一点的去看,带着理论知识去理解源码,反过来用源码的实现原理来纠正和补充理论知识,在这个过程中可以快速提高自己。
3.说说读完试读章节后您的感想?
这是本非常好的书,可以对着作者以前写的innodb引擎的那本书一起结合看。试读章节主要分享了两章内容:
第一章是概括性的知识,介绍了INNODB存储引擎的历史,如果知道的同学可以直接略过,后续内容对于源码的版本,风格,编译的方式做了一些介绍,主要是给我们一个源码阅读的认识,对于作者分析的源码方法十分认可,按照层次去阅读,这样可以非常容易的去理解。对于我们这些源码分析的初学者来说可以按照作者的建议,进行按部就班的阅读。
第二章介绍了一些INNODB存储引擎的内存管理的实现,基本数据结构,对于后续做个铺垫。以前都是直接学习理论,记住了这些的内容就可以了,现在从源码角度可以去看看实现方式。这些内容如果前期学的比较深入的话,可以大体看看,如果对这些链表,内存管理方法不是很清楚的可以好好读读,毕竟这是深入学习的基础。
这是分析源码方式的卷1,后续期待作者更多精彩的内容分享。让更多的人喜欢并且可以阅读源码,为开源化数据库作出贡献。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询