百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

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

bigegpt 2024-08-11 14:29 8 浏览

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

思考题

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

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

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

加油 MySQLer,respect ~~~

相关推荐

ActiveAndroid使用(对象化数据库)

配置模块的build.gradlerepositories{mavenCentral()mavenLocal()maven{url"https://oss.sonatype.org/conte...

AndroidStudio下的依赖管理(android app依赖外部jar包)

在开发中用第三方库是很常见的事,如何在AndroidStudio下管理这些依赖呢?这就是这篇文章的目的。目录Maven/Ivy仓库依赖Module依赖aar文件依赖jar文件依赖例子完整代码一、Mav...

Android Studio之gradle的配置与介绍

1、gradle的简单介绍Gradle是可以用于Android开发的新一代的BuildSystem,也是AndroidStudio默认的build工具。其实Gradle脚本是基于一种JVM语言—...

Android中的run-as命令带来的安全问题

一、前言最近一周比较忙,没时间写东西了,今天继续开始我们今天的话题:run-as命令,在上周的开发中,遇到一个问题,就是在使用run-as命令的时候出现了一个错误,不过当时因为工作进度的问题,这问题就...

Android系统级深入开发——input驱动程序

1、Input驱动程序是Linux输入设备的驱动程序,分成游戏杆(joystick)、鼠标(mouse和mice)和事件设备(Eventqueue)3种驱动程序。其中事件驱动程序是目前通用的驱动程序...

Android项目中如何用好构建神器Gradle?

CSDN移动将持续为您优选移动开发的精华内容,共同探讨移动开发的技术热点话题,涵盖移动应用、开发工具、移动游戏及引擎、智能硬件、物联网等方方面面。如果您想投稿、参与内容翻译工作,或寻求近匠报道,请发送...

Android Studio自定义文件类头(android studio自定义标题栏)

--简书作者谢恩铭转载请注明出处今天给大家介绍一个很简单的"小"技巧。平时,我们在AndroidStudio中开发Android时,总免不了要创建新的文件,也许是Java文件,也许是C...

C语言#include头文件真的是插入代码吗?

若文章对您有帮助,欢迎关注程序员小迷。助您在编程路上越走越好!编译器理论和实作既是又不是。从编译器理论理解,#include头文件"相当于"插入了头文件的代码,以供源代码引用(宏定...

Android 系统核心机制binder(03)binder C++层实现

本章关键点总结&说明:这里主要关注BinderC++部分即可,看到,也是本章节的核心内容,主要就是以C++封装的框架为主来解读binder。之前主要针对于底层驱动binder的数据交互以及...

Java对象序列化与反序列化的那些事

Java对象序列化与反序列化的那些事在Java的世界里,对象序列化和反序列化就像一对孪生兄弟,它们共同构成了Java对象存储和传输的基础。如果你曾经尝试将对象保存到文件中,或者在网络中传输对象,那么你...

Java对象序列化剖析(java 对象序列化)

对象序列化的目的1)希望将Java对象持久化在文件中2)将Java对象用于网络传输实现方式如果希望一个类的对象可以被序列化/反序列化,那该类必须实现java.io.Serializable接口或jav...

C++模板 - 16(SFINAE)(c++模板编程)

C++支持函数重载,同一个函数名,只要它的签名不一样,可以声明若干个版本(这个特性也是必须的,不然构造函数就只能有一个了)。现在函数的重载集合中又加入了新的成员-函数模板,事情就变得越发有趣起来,...

NewtoSoft.Json相关使用技巧(newtosoft.json相关使用技巧有哪些)

  本篇将为大家介绍Newtonsoft.Json的一些高级用法,可以修改很少的代码解决上述问题。Newtonsoft.Json介绍  在做开发的时候,很多数据交换都是以json格式传输的。而使用Js...

C#调用DeepSeek API(c#调用deepseek api 流式输出)

一、官方网站二、DeepSeek测试DeepSeek三大适用模式:基础模型(V3)、深度思考(R1)、联网搜索。基础模型(V3)深度思考(R1)联网搜索三、C#调用DeepSeekAPI核心代码//...

.NET性能系列文章二:Newtonsoft.Json vs System.Text.Json

微软终于追上了?图片来自GlennCarstens-Peters[1]Unsplash[2]欢迎来到.NET性能系列的另一章。这个系列的特点是对.NET世界中许多不同的主题进行研究、基准和比较...