查看原文
其他

用 VSCode 编译和调试 MySQL,每个 DBA 都应 get 的小技能

破产码农 InsideMySQL 2022-10-13

        

破产码农

IT圈最会讲故事的网红 · 南山彭于晏

如果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 编译和调试 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 进程,这样就能进行源码级别的调式了:


视频教程


最后,视频是最好的教程,看看同学们是不是能通过 VSCode 进行 MySQL 源码级编译和调试了呢?

通过编译和调试的小伙伴请在留言区发言,谈谈你们对于 VSCode 调试 MySQL 源码的感受。
若在使用 VSCode 中存在问题,也欢迎留言哦~~~

思考题


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

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


欢迎修改成功的小伙伴在评论区留言哦。
加油 MySQLer,respect ~~~

直播预告


每周五、六,不定期直播,分享技术干货


IMG群是码农的交流社区,IMG微信群交流内容包括但不限于技术、经济、军事、八卦等话题。欢迎有态度的码农们加入IMG大家庭。
IMG目前有少林群、武当群、峨眉群、华山群、M悦会(高端VIP群)
仅限码农入群,猎头或其他行业勿加,入群请加姜老师个人微信 82946772,并备注:码农入IMG群
-----------------------
公众号:破产码农
视频号:破产码农
抖音号:破产码农
B站号:姜老师带你飞
长按下图二维码关注,将感受到一个有趣的灵魂,每篇文章都会有新惊喜。

          

往期推荐

老盖除名 Oracle ACE ,旧时代的终结!


收藏!最新《MySQL数据库开发设计规范》


这么哇塞的 MySQL 功能,你确定不用么?


作为新生代农民工,码农30岁存款应该有多少?


关于 O_DIRECT 的正确答案!


您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存