聊聊 MySQL8.0 源码编译和 Clion 调试

数据库 MySQL
如果Clion的CMake执行成功后,就会出现对应的 Run / Debug Configurations 选项,里边会有名称为mysqld的选项,它就是 MySQL Server 启动的选项。可以先用该选项执行 MySQL 数据目录的初始化操作,生成对应的配置文件和用户名密码。

​操作系统环境

我把个人的台式机重装了 Ubuntu 20.04 ,内核版本是 5.13.0-44-generic,内存16G,磁盘240G,有关依赖的编译工具版本如下所示。

图片

相关的安装命令是从 PolarDB-通过编译源码安装部署文档上来的,专门适配于 Ubuntu 20版本,Centos的版本可以具体去它文档中查看:

安装GCC7
apt install -y gcc-7 g++-7
update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-7 60 \
--slave /usr/bin/g++ g++ /usr/bin/g++-7
update-alternatives --config gcc
gcc --version
g++ --version

# 安装依赖
apt install make automake cmake git bison libaio-dev libncurses-dev libsasl2-dev libldap2-dev libssl-dev pkg-config

MySQL 源码下载

我们选择最新的 8.0.28版本,可以去 https://dev.mysql.com/downloads/mysql/ 直接下载带 Boost 第三方库依赖的源码。

图片

Boost 是一个功能强大、构造精巧、跨平台、开源并且完全免费的 C++ 程序库,可以认为是半个C++标准库。MySQL 的代码依赖 Boost库,所以直接下载一个携带Boost库的源码比较省心,不需要再去下载对应的Boost库。

编译命令

我们首先需要使用 cmake 进行编译,可以直接使用命令行,也可以用 Clion 开发后,配置对应的cmake编译配置。

图片

其中,有关 CMake Options 的部分参数如下所示:

-DWITH_BOOST=~/work/c++/mysql-8.0.28/boost -DCMAKE_BUILD_TYPE=Debug -DCMAKE_INSTALL_PREFIX=/home/homer/build -DMYSQL_DATADIR=/home/homer/build/data -DSYSCONFDIR=/home/homer/build -DMYSQL_UNIX_ADDR=/home/homer/build/data/mysql.sock -DMYSQL_MAINTAINER_MODE=false

其中比较重要的有:

  • DWITH_BOOST: 指定 boost 路径,可以直接指向源码文件夹下的boost文件夹;
  • DCMAKE_BUILD_TYPE: 表示是debug,方便后续代码调试;
  • DCMAKE_INSTALL_PREFIX:  表示编译状态的路径,选择源码文件夹之外的一个自建的build文件夹
  • DMYSQL_DATADIR:表示MySQL默认的数据目录,选择build文件夹下的data文件

然后执行命令进行编译,大概会花费数分钟的时间,并且可能会出现各类错误和问题。问题和错误会在本文后边进行记录。

Clion 调试

如果Clion的CMake执行成功后,就会出现对应的 Run / Debug Configurations 选项,里边会有名称为mysqld的选项,它就是 MySQL Server 启动的选项。可以先用该选项执行 MySQL 数据目录的初始化操作,生成对应的配置文件和用户名密码。然后再使用该选项来启动 MySQL Server。两个操作对应的参数不同。

图片

第一步初始化数据目录时,也需要先创建对应的用户。

# 创建 MySQL 用户组和 MySQL 用户
groupadd mysql
useradd -r -g mysql -s /bin/false mysql

然后使用 clion 的 mysqld 执行选项,输入的 Program arguments 如下所示:

--basedir=/home/homer/build --datadir=/home/homer/build/data --lower_case_table_names=0 --initialize-insecure --user=mysql

其中 --initialize-insecure 表示非安全的初始化,可以设置无密码的用户。然后需要给对应的文件夹添加读写和执行权限。

chmod -R 777 /home/homer/build/data

初始化后,就可以继续使用 clion 的 mysqld 执行选项来启动 MySQL了。输入的 Program arguments 如下所示:

--basedir=/home/homer/build --datadir=/home/homer/build/data --lower_case_table_names=0 --user=mysql

图片

然后我们可以在 /home/homer/build/bin 目录下执行 ./mysql -uroot -h127.0.0.1 -P3306 -p来使用客户端连接 MySQL Server。登录时无需密码,直接回车。

图片

然后就可以看到我们在clion中设置断点的代码逻辑被拦截,下面我们就可以进行调试和代码阅读了。

问题记录

在整个过程中,特别是编译阶段遇到了很多问题,这里也简单记录一下,相信不同的同学进行这个过程中都会遇到不同的问题,大家耐心解决。

1.default.cfg不存在

编译时会有如下报错:

CMake Error: File /home/homer/work/c++/mysql-8.0.28/router/src/harness/tests/data/logger.d/default.cfg does not exist.
CMake Error at router/cmake/testing.cmake:211 (CONFIGURE_FILE):

可以在 cmake配置文件中找到如下片段,直接删除。

CONFIGURE_TEST_FILE_TEMPLATES(${CMAKE_CURRENT_SOURCE_DIR}/data
"tests-good-1.cfg.in;tests-good-2.cfg.in;tests-start-1.cfg.in")
SET(TEST_FILES
logger.cfg
magic-alt.cfg
tests-bad-1.cfg
tests-bad-2.cfg
tests-bad-3.cfg
)

2.编译警告作为错误处理

在编译过程中,发现编译器会把warning当做error处理,导致整个编译过程失败。具体报错如下所示。

cc1plus: all warnings being treated as errors

经过搜索最终在 https://dev.mysql.com/doc/mysql-sourcebuild-excerpt/8.0/en/compilation-problems.html 文档中找到了对应的解决版本,需要将DMYSQL_MAINTAINER_MODE设置为false,否则就会导致编译器将warning作为error处理。

嵌入可以理解为一种组合或者代理模式的自动语法糖。

3.编译cache

编译异常后,需要删除对应的 cmake cache 后再次进行编译,否则每次都会读取缓存进行相同的报错。

责任编辑:武晓燕 来源: 程序员历小冰
相关推荐

2023-03-29 08:13:48

MySQL检索成本

2013-05-28 10:52:07

Android开发移动开发移动应用

2022-10-10 08:01:08

MySQL字典表

2018-11-28 15:00:58

MySQLGROUP BY索引

2021-06-03 19:13:06

MySQLJson数据

2023-01-02 08:20:14

MySQL数据库

2017-03-27 15:15:43

Hive源码编译

2011-03-08 10:18:18

Visual StudMongoDB

2022-08-29 08:01:01

MySQL配置Windows

2021-10-17 19:52:40

Python:源码编译器

2021-10-19 10:26:31

MySQL.MySQLJSON

2021-02-02 21:50:31

MySQL 8.0ExcelMySQL 5.7

2021-05-31 19:50:04

MySQL自增锁InnoDB

2023-03-28 07:12:21

开源IoT平台源码

2024-03-25 07:30:03

MySQL数据库SQL日志

2020-12-31 05:35:53

MySQL 8.0MySQL 5.7JSON

2010-06-02 13:05:14

Sendmail 安装

2020-11-03 14:30:02

MySQL5.7MyS8.0数据库

2024-01-30 08:01:22

MySQL数据库分组排序

2021-06-08 07:49:29

MySQL数据库索引
点赞
收藏

51CTO技术栈公众号