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 .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/

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

  1. MySQL源码 数据结构hash

    MySQL源码自定义了hash表,因为hash表具有O(1)的查询效率,所以,源码中大量使用了hash结构.下面就来看下hash表的定义: [源代码文件include/hash.h mysys/has ...

  2. mysql源码安装(5.1)

    下载mysql源码包并解压.wget http://dev.mysql.com/get/Downloads/MySQL-5.1/mysql-5.1.73.tar.gztar -zxvf mysql-5 ...

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

    安装环境: CentOS6.3 64位 软件: Mysql-5.6 所需包: gcc/g++ :MySQL 5.6开始,需要使用g++进行编译.cmake  :MySQL 5.5开始,使用cmake进 ...

  4. [转]MySQL源码:Range和Ref优化的成本评估

    MySQL源码:Range和Ref优化的成本评估 原文链接:http://www.orczhou.com/index.php/2012/12/mysql-source-code-optimizer-r ...

  5. mysql源码编译安装

    首先去官网http://dev.mysql.com/downloads/mysql/ 下载mysql源码.我下的是5.7.10 源码选择的是 Generic Linux (Architecture I ...

  6. Dubbo入门到精通学习笔记(十九):MySQL源码编译安装、MySQL主从复制的配置

    文章目录 MySQL 源码编译安装(CentOS-6.6+MySQL-5.6) 一.服务器配置: 二.源码安装 MySQL5.6.26: MySQL主从复制的配置 环境 依赖课程 MySQL 主从复制 ...

  7. MySQL源码解析之执行计划

    MySQL源码解析之执行计划 MySQL执行计划介绍 MySQL执行计划代码概览 MySQL执行计划总结 一.MySQL执行计划介绍 在MySQL中,执行计划的实现是基于JOIN和QEP_TAB这两个 ...

  8. mysql源码解读之配置文件

    要研究mysql,最好的资源莫过于源码了,所以本人打算通过调试源码的方式来深入理解mysql的点点滴滴.搭建mysql调试环境很简单,从官方下载mysql源码,利用cmake工具生成工程即可.为了方便 ...

  9. MySQL源码分析以及目录结构 2

    原文地址:MySQL源码分析以及目录结构作者:jacky民工 主要模块及数据流经过多年的发展,mysql的主要模块已经稳定,基本不会有大的修改.本文将对MySQL的整体架构及重要目录进行讲述. 源码结 ...

随机推荐

  1. SELECT样式,兼容IE6

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. [selenium webdriver Java]元素定位——findElement/findElements

    策略 语法 语法 描述 By id driver.findElement(By.id()) driver.findElements(By.id()) 通过id属性定位元素 By name driver ...

  3. Tableau学习笔记之三

    1.Tableau可以连接多种多样的数据以及数据库,例如txt,xls,mdb,sql server,oracle等等 2.Tableau还可以从剪贴板上粘贴数据 3.维度和度量的理解: 1)维度即表 ...

  4. [原创]Android应用 - YE启动器APP(YeLauncherApp)

      支持解冻.冻结APP 支持在本APP列表隐藏指定APP 支持检测系统核心APP,防止误点冻结导致手机变砖 支持清理APP缓存 支持强制停止APP Apk文件仅仅47KB 自用.开源 类似APP:A ...

  5. js控制不同的时间段显示不同的css样式

    js控制不同的时间段显示不同的css样式 js函数,可以放到单独的js文件中也可以放到当前页的<head>标记之内 function getCSS(){        datetoday ...

  6. jQuery-validate error messages in Twitter ...

    http://www.jefclaes.be/2012/11/jquery-validate-error-messages-in.html something satisfactory. In thi ...

  7. google_protobuf数据类型

    要通信,必须有协议,否则双方无法理解对方的码流.在protobuf中,协议是由一系列的消息组成的.因此最重要的就是定义通信时使用到的消息格式. Protobuf消息定义 消息由至少一个字段组合而成,类 ...

  8. Spring Filter components in auto scanning

    In this Spring auto component scanning tutorial, you learn about how to make Spring auto scan your c ...

  9. [iOS基础控件 - 6.11.2] - UINavigationController 多控制器 简单使用

    A.概念 1.通常一个app有多个控制器 2.需要对这些控制器进行管理 3.有多个view的时候,用一个父view去管理多个子view 4.控制器管理也是如此,使用给一个父控制器,去控制子控制器   ...

  10. HDU 4431 Mahjong (DFS,暴力枚举,剪枝)

    题意:给定 13 张麻将牌,问你是不是“听”牌,如果是输出“听”哪张. 析:这个题,很明显的暴力,就是在原来的基础上再放上一张牌,看看是不是能胡,想法很简单,也比较好实现,结果就是TLE,一直TLE, ...