深入MySQL源码 学习方法 何登成专家

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/
时间: 2024-10-24 00:17:55

深入MySQL源码 学习方法 何登成专家的相关文章

mysql源码安装(5.1)

下载mysql源码包并解压.wget http://dev.mysql.com/get/Downloads/MySQL-5.1/mysql-5.1.73.tar.gztar -zxvf mysql-5.1.73cd mysql-5.1.73 创建用户.basedir datadiruseradd -s /sbin/nologin  mysqlmkdir -p /usr/local/mysqlmkdir -p /data/mysqlchown mysql /data/mysql 编译前的参数配置.

MySQL系列 - MySQL源码安装配置

二.MySQL系列 - MySQL源码安装配置(附5.7等最新版本)1.依赖环境准备2.开始安装2.1.下载MySQL2.2.解压2.3.赋权限2.4.修改配置文件2.5.启动MySQL3.MySQL 5.7源码安装不同之处 二.MySQL系列 - MySQL源码安装配置(附5.7等最新版本) 1.依赖环境准备 make安装 make编译器下载地址:http://www.gnu.org/software/make/ # tar zxvf make-3.82.tar.gz # cd make-3.

MySQL源码编译安装(CentOS-6.6+MySQL-5.6)

MySQL源码编译安装(CentOS-6.6+MySQL-5.6) 部署环境 操作系统:CentOS-6.6-x86_64-bin-DVD1.iso MySQL版本:mysql-5.6.26.tar.gz 操作用户:root 系统IP:192.168.1.205 主机名:edu-mysql-01 配置:4核.4G内存 一.服务器配置: 1.配置网络 # vi /etc/sysconfig/network-scripts/ifcfg-eth0 DEVICE=eth0 BOOTPROTO=stati

MySQL源码 优化器

完成了sql的解析过程后,开始进入优化器: 调用的流程分为: mysql_select: JOIN::prepare: JOIN::optimize: JOIN::exec: prepare过程: 组装各个组件,包括:stepup tables, fields, condition, order 1. tables: setup_tables_and_check_access:从table_list中检查访问权限,并加入到leaf_tables中,增加tables计数. setup_tables

Linux(CentOS或RadHat)下MySQL源码安装

安装环境: CentOS6.3 64位 软件: Mysql-5.6 所需包: gcc/g++ :MySQL 5.6开始,需要使用g++进行编译.cmake  :MySQL 5.5开始,使用cmake进行工程管理,cmake需要2.8以上版本.bison  :MySQL语法解析器需要使用bison进行编译.ncurses-devel :用于终端操作的开发包.zlib    :MySQL使用zlib进行压缩 有关库包下载: 可以自己去官网下载,也可以去网盘下载 http://pan.baidu.co

Win7+VS2010:mysql 源码编译与调试

win7+vs2010源码编译mysql 最近由于在实习,工作重点在于一些数据库的开发,为了更好的理解数据库的实现机制,目前萌生了要研究一下mysql数据库源码的想法.那么好吧,说干就干,首先我们需要实现对源码的编译,这里我们选择win7+VS2010来实现,但是试了很多次都失败了.这是我多次配置环境时遇到的问题,各种博客文章总是不太完全,或者说没有说明一些遇到的问题的解决方案,这可能跟具体的操作系统和环境有关.本文就说说我安装的情况. 1. 准备工作 (1)OS:win7 旗舰版 64位 + 

MySQL源码 数据结构hash

MySQL源码自定义了hash表,因为hash表具有O(1)的查询效率,所以,源码中大量使用了hash结构.下面就来看下hash表的定义: [源代码文件include/hash.h mysys/hash.c] typedef uint my_hash_value_type; typedef uchar *(*my_hash_get_key)(const uchar *,size_t*,my_bool); typedef void (*my_hash_free_key)(void *); type

MySQL源码编译安装

1.安装cmake-2.8.10.2.tar.gz 以root用户进入shell #tar -zxvf  cmake-2.8.10.2.tar.gz #cd cmake-2.8.10.2 #./configure #make                         (无法make,检测gcc编译环境) #make install --------------------------------- 2.安装ncurses-5.9.tar.gz #tar -zxvf  ncurses-5.9

在win7 下编译MySQL源码

MySQL MySQL是一款优秀的开源数据库,在阿里.网易等各个互联网公司中有着广泛的应用.尽管各种NoSQL大行其道,但是关系型数据库依然必不可少. 作为一个新手,在Win7下用源码安装MySql数据库并不容易.我自己都折腾了好几天.今天把安装过程记录下来,其一是为了方便自己以后学习,其二则是分享过程,让学习者能够从我这篇文章中受益. 1. 编译环境及源码下载 编译环境:Visual Studio 2010 (Win7 32位) 编译工具: bison-2.4.1-setup.exe 下载地址