深入MySQL源码 学习方法
https://wenku.baidu.com/view/c8cb23a9aef8941ea66e0518.html
MYSQL 技术圈
有哪些做得好,又注重分享的公司: Oracle MySQL, MariaDB, Percona,Google, FB, Twitter, Taobao, NetEase…
有哪些值得关注的个人: Mark Callaghan、 Jeremy Cole、 Dimitri、 Peter ,Zaitsev、 Yoshinori Matsunobu …
微博上有哪些值得关注的账号: @姜承尧、 @淘宝丁奇、 @plinux、 @那海蓝蓝 …
业界有哪些好的会议: Percona Live、 FOSDEM、 MySQL Connect …
哪里去提问和找答案: Google、 StackOverflow …
跟踪MySQL每个发行版和Bugs
关于这一点,个人曾经跟霸爷@淘宝褚霸有过一次讨论。
霸爷说:在过去几年,跟踪Erlang,把Erlang语言每个版本/每个提交的变 更都看了一遍;
我说我没有这么执着,但是我也把MySQL 5.1以来各版本的Release Notes、 Bug Fix都跟踪过,新增的功能,都阅读过代码,调试跟踪分析过其实现; 要想深入了解MySQL,或者是其他的系统,你需要做到几年如一日的 跟踪其发展,才能真正的做到不落伍;
一个关于Oracle DBA的典故; 曾经有一位Oracle DBA,被Oracle公司请去对其公司内的Oracle研发人员 做关于Oracle系统的培训
哪些地方可以获取这些资料?
WorkLogs MariaDB: https://mariadb.atlassian.net/secure/Dashboard.jspa MySQL: https://dev.mysql.com/worklog/ Percona: https://launchpad.net/percona-server Bug 库 MySQL Bugs Home: http://bugs.mysql.com/ Percona Bugs Home: https://bugs.launchpad.net/percona-server 各发行版本 历史版本: http://downloads.mysql.com/archives/community/ 当前版本: http://dev.mysql.com/downloads/mysql/
我的经验
——定期更新自己的前期知识
随着对MySQL系统理解的深入,此时应该定期回过头来看看自己早期
整理的笔记,撰写的文章,相信我,你一定会发现很多错误,嗤之以
鼻的想法。
无须沮丧,这说明你的能力提高了,更正他们。
个人经验
就InnoDB的锁实现一个功能,近三年内,每当有点新的思路,想
法,我就会去重新做测试,看代码,不断纠正自己的想法。
最近的一篇文章: 《 MySQL加锁处理分析》
但在我现在看来,这篇文章中仍旧有不正确的地方…
——注重发散知识的积累
看懂MySQL源码不是最终目标,当你觉得很多你看懂了,你就会有新的追求,此时,
也就意味着需要积累新的知识;
对MySQL的并发处理不满意? Kernel_mutex?
需要学习并发编程的相关知识;
对MySQL单线程复制不满意?延迟严重?
需要学习MySQL现有复制的实现,进行多线程改造;
对MySQL压缩功能不满意?
了解业界成熟的压缩算法,尝试实现并替换;
对InnoDB引擎不满意?
自己做一个引擎,你需要进一步了解其他数据库/NoSQL/NewSQL的优点;
——写在最后的建议
能坚持到/看到这里的,那绝壁是真爱!! 赠送两个小小的建议
建议一: 从handler出发 MySQL插件式引擎,连接MySQL Server与各种存储引擎的,是其Handler 模块 —— hanlder模块是灵魂; 以InnoDB引擎为例,从ha_innodb.cc文件出发,理解其中的每一个接口的 功能,能够上达MySQL Server,下抵InnoDB引擎的内部实现;
建议二: 不放过源码中的每一处注释 MySQL/InnoDB源码中,有很多注释,一些注释相当详细,对理解某一个 函数/某一个功能模块都相当有用;
个人推荐的相关书籍
首先,以下推荐的书籍,我都保证是自己看过的,有的看过不止一遍; MySQL. 《 MySQL Reference Manual》 Baron Schwartz, Peter Zaitsev, Vadim Tkachenko. 《 High Performance MySQL, 3rd Edition》 Sasha Pachev. 《 Understanding MySQL Internals》 J. M. Hellerstein, M. Stonebraker, J. Hamilton. 《 Architecture of a Database System》 Jonathan Lewis. 《 Oracle Core: Essential Internals for DBAs and Developers》 Jonathan Lewis. 《 Cost-Based Oracle Fundamentals》 Steve Adams. 《 Oracle8i Internal Services for Waits, Latches, Locks, and Memory》 Oracle. 《 Oracle Data Server Internals: Oracle DSI》 姜承尧. 《 MySQL技术内幕: InnoDB存储引擎》
个人推荐的相关博客
以下的这些MySQL相关的博客,都是个人订阅,并且每天关注更新的; 有时间与经历,建议将这些博客中过去的博文,都看一遍; Planet MySQL http://planet.mysql.com/ Mark Callaghan http://mysqlha.blogspot.com/ Jeremy Cole http://blog.jcole.us/ Percona http://www.mysqlperformanceblog.com/ Oracle InnoDB https://blogs.oracle.com/mysqlinnodb/ Morgan Tocker http://www.tocker.ca/ Dimitri KRAVTCHUK http://dimitrik.free.fr/blog/index.html Yoshinori Matsunobu http://yoshinorimatsunobu.blogspot.com/
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!