如果5年前有人问:MySQL DBA需要拥有内核开发的技能么?

我会说:不需要。

2021年的这个时间,若有人问:MySQL DBA需要拥有内核开发的技能么?

我依然会坚持道:不需要。

但是会补充道:MySQL DBA 不要求能进行数据库内核层面的开发,但是要能进行一般内核问题的故障诊断与分析。

因此,学会编译和调试 MySQL 源码就是当前一个必备技能了。

在我10年前撰写的书籍《MySQL技术内幕:InnoDB存储引擎》有关于内核代码的调试,可惜是基于 Visual Studio 。

用 Visual Studio 编译和调试 MySQL 和线上用 gdb 处理问题依然有很大的区别。

更重要的是,那时还没有 VSCode (Visual Studio Code)这样的跨平台杀手级 IDE 。

VSCode 一出,其他 IDE 都成为了”垃圾“。

打开网易新闻 查看精彩图片

VSCode Remote SSH

VSCode Remote SSH

在开始介绍如何通过 VSCode 编译和调试 MySQL 数据库前,我们先介绍 VSCode 的一个杀手级插件:Remote SSH。

上述插件简单来说就是:通过SSH技术,可以本地编写、编译、调试在远程存储的代码。

以前开发大致需要经过:本地开发环境 -> 测试环境 -> 联调环境 -> 预发布环境 -> 线上环境

而本地开发环境由于操作系统是 Windows、Mac等,总存在各种各样的依赖。

通过 VSCode 的 Remote SSH 插件,码农们基本就统一了本地开发环境和测试环境。

而 Remote 的这台主机可以是一台性能超级强劲的云主机,如 32 核 64G,通常来说,都要比本地主机性能好很多。

BTW,Win 10 推出了 WSL (Windows Subsystem Linux ),通过 Remote WSL 插件可以无缝连接到 Win 10 内置的 Linux 系统。

对于不想申请云主机,就想在 Windows 下开发的同学来说,这又是一个真香系列。

总之,VSCode + WSL 是微软 CEO 纳德拉上台后,推出的最好技术产品。

打开网易新闻 查看精彩图片

试问,若你是纳德拉,在微软风雨飘摇的时候上台,如何快速讨好流失的用户呢?

纳德拉其实真是一个很棒的产品经理!

小 tips :GitHub Codespaces

编译和调试 MySQL 源码

之前网上有一篇如何使用 VSCode 编译和调试 MySQL 源码的文章。

很可惜,那篇文章没有充分发挥 CMake 的威力以及理解 VSCode 的拥有能力。

配置上过于繁琐,不是一个如 VSCode 优秀 IDE 应该的使用姿势。

接着让姜老师 step by step 教大家如何使用 VSCode 编译和调试 MySQL 源码。

首先,在本地 VSCode 中安装插件:Remote SSH

接着,按 Ctrl + Shift + p,通过 Remote 插件连接到远程的 Linux 服务器或本地 WSL,并打开远程服务器上的 MySQL 源码文件夹:

打开网易新闻 查看精彩图片

上述操作都完成后,在 VSCode 左侧(默认),你应该能看到类似如下的界面:

打开网易新闻 查看精彩图片

SSH:DAVID_DEV 表示是通过 Remote 插件连接到的远程服务器。

OUTLINE显示的是打开源码文件中对应的函数和变量等信息。

接着,在远程远程服务器上依次安装 C/C++、CMake、CMake Tools插件,如:

切记,上述三个插件要安装在 Remote 环境下,不要安装在 LOCAL 本地。否则远程服务器无法编译和调试源码。

在安装完 CMake Tools 插件后,在 VSCode 的底部,可以看到 CMake 的配置选项:

最左侧是选择编译的版本,按下CMake会出现Debug、Release、MinSizeRel、RelWithDebInfo 的编译版本选择。

中间部分是选择编译器,如 GCC、llvm、Clang 的版本,点击会出现类似如下的选项:

打开网易新闻 查看精彩图片

这里我选择了 GCC 9.3.1。

之后的齿轮图片⚙表示进行BUILD编译;蜘蛛图片表示调试按钮;最后的箭头表示表示启动程序,这里选择启动 mysqld 这个程序。

好了,到这就可以进行第一步编译了。

在编译前,还需要对 CMake 做一些配置,因为 MySQL 源码依赖 boost 库,这个库没有随源码一起分发,需要独立下载。

因此,按下 Ctrl + , 在 CMake 插件中的Workspace选项卡中,进行如下配置:

打开网易新闻 查看精彩图片

完成这一步,接着点击底部的 BUILD 按钮,就可以顺利的完成编译工作了。

打开网易新闻 查看精彩图片

要启动 mysqld 程序的话,还需要配置额外的参数,需要在配置文件 settings.json 中进行如下配置:

"cmake.debugConfig": {

"args": ["--user=mysql --datadir=..."],

}

这样就可以进行 mysqld 程序的启动和调试。

若通过 VSCode 设置断点,VSCode 会调式中通过 gdb attach 到 mysqld 进程,这样就能进行源码级别的调式了:

打开网易新闻 查看精彩图片

思考题

思考题

相信现在同学们已经学会了编译、调试 MySQL 源码的工作。

现在修改 MySQL 源码,自定义 MySQL 的版本,如:

打开网易新闻 查看精彩图片

欢迎修改成功的小伙伴在评论区留言哦。

加油 MySQLer,respect ~~~