解锁MySQL 8.0.41源码调试:Mac 11.6+CLion 2024.3.4实战指南

文章目录

  • 解锁MySQL 8.0.41源码调试:Mac 11.6+CLion 2024.3.4实战指南
    • 前期准备
    • 环境搭建详细步骤
      • 安装 CLion
      • 安装 CMake 3.30.5
      • 准备 MySQL 8.0.41 源码
      • 配置 CMake 选项
      • 构建 MySQL 项目
    • 调试环境配置与验证
      • 配置 LLDB 调试器
      • 启动调试
      • 验证调试环境
    • 总结与拓展
    • 碰到的问题
      • 1. ld: unknown option: -no_warn_duplicate_libraries
      • 2 .std::bit_floor 未定义
      • 3.无法从 archives.boost.io 下载 Boost 1.77.0 源码包
      • 4.MySQL 启动时 component_reference_cache.so 缺失
      • 5.修复 Unix Socket 锁文件创建失败
    • 参考

解锁MySQL 8.0.41源码调试:Mac 11.6+CLion 2024.3.4实战指南

前期准备

在这里插入图片描述

环境搭建详细步骤

安装 CLion

首先,前往JetBrains 官网下载适用于 Mac 系统的 CLion 安装包。下载完成后,将安装包拖动到 “应用程序” 文件夹进行安装。安装过程中,可能会要求输入管理员密码以完成安装操作。安装完成后,首次打开 CLion 时,会提示进行一些初始设置,例如选择主题、导入设置等,可以根据个人喜好进行配置。

安装 CMake 3.30.5

下载:我用的cmake工具为Clion捆绑的,所以不需要单独下载。

安装:安装完Clion就有cmake工具了。如下图:

在这里插入图片描述
CMake 是一个强大的跨平台编译工具,它使用简单的配置文件来描述编译过程,能够生成适用于各种平台的makefile或项目文件。CMake的主要功能包括编译自动化和跨平台支持,它可以极大地提高软件开发的效率,特别是在涉及多个项目和复杂依赖关系时。

准备 MySQL 8.0.41 源码

获取源码

git clone https://gitee.com/mirrors/mysql-server.git
git checkout 8.0

配置 CMake 选项

打开mysql-server项目时,会自动弹出如下页面,这样我们就可以配置了。
在这里插入图片描述
-DDOWNLOAD_BOOST=0:表示不自动下载 Boost 库,因为我们已经指定了 Boost 库的路径。前提是我们用以下命令把boost库下载到指定目录了。如下:

curl -L -o ~/Downloads/boost_1_77_0.tar.bz2 https://sourceforge.net/projects/boost/files/boost/1.77.0/boost_1_77_0.tar.bz2/download
mv ~/Downloads/boost_1_77_0.tar.bz2 ~/CLionProjects/mysql-server/boost/

-DWITH_BOOST=/Users/shandian/CLionProjects/mysql-server/boost:指定 Boost 库的路径,让 MySQL 在编译时能够找到 Boost 库。

-DCMAKE_BUILD_TYPE=Debug:设置构建类型为 Debug,这样在调试时能够包含更多的调试信息。

-DCMAKE_INSTALL_PREFIX=~/CLionProjects/mysql-server/build_out:指定安装路径,编译后的文件将安装到这个目录。

-DMYSQL_DATADIR=/Users/shandian/CLionProjects/mysql-server/build_out/data:指定 MySQL 的数据目录。
注意:如果有多次初始化,需要把前一次生成的的文件先删除掉,不然会导致初始化失败

-DSYSCONFDIR=~/CLionProjects/mysql-server/build_out:指定 MySQL 的配置文件目录。

-DMYSQL_UNIX_ADDR=/Users/shandian/CLionProjects/mysql-server/build_out/data/mysql.sock:指定 MySQL 的 Unix 套接字文件路径。

-DMYSQL_MAINTAINER_MODE=false:关闭维护者模式,减少编译时的一些额外检查。

构建 MySQL 项目

打开 CLion,点击 “Create New Project”。

在弹出的窗口中,选择 “Import Project”,然后找到 MySQL 源码所在目录/Users/shandian/CLionProjects/mysql-server

在 “CMake Options” 中输入之前配置好的 CMake 选项。

在 “Build Directory” 中指定构建目录为/Users/shandian/CLionProjects/mysql-server/build_out

点击 “OK”,CLion 会自动加载项目并开始配置 CMake。

配置完成后,点击 CLion 界面右上角的 “Build” 按钮开始构建项目。构建过程可能会持续一段时间,期间可能会下载一些依赖库,如果遇到网络问题导致下载失败,可以手动下载并放置到相应目录。构建完成后,如果没有报错,就可以开始进行调试了。

调试环境配置与验证

配置 LLDB 调试器

如果 CLion 的 CMake 执行成功后,就会出现对应的 Run / Debug Configurations 选项,如下所示:

在这里插入图片描述

打开 CLion,进入 MySQL 项目。点击菜单栏中的 “Run” -> “Edit Configurations”。

在弹出的配置窗口中,找到 “Configuration” 选项卡。

在 “Debugger” 下拉框中选择 “LLDB19.1.3”。

确保 “Use bundled LLDB” 选项被勾选,这样 CLion 就会使用捆绑的调试器进行调试。
在这里插入图片描述

点击 “OK” 保存配置。此时,LLDB 调试器已经配置完成,它将在后续的调试过程中发挥作用,帮助我们分析 MySQL 程序的执行流程和变量状态。

启动调试

在 CLion 的代码编辑界面中,找到需要调试的代码位置,例如sql/``session.cc文件中的某个函数,在代码行号旁边点击,设置断点。断点是调试过程中的关键标记,当程序执行到断点处时,会暂停执行,方便我们查看程序状态。

设置好断点后,点击 CLion 界面右上角的绿色虫子图标(Debug 按钮),或者使用快捷键Command + Shift + F9启动调试。

程序开始运行,当执行到设置的断点时,会暂停下来。此时,CLion 的调试窗口会显示当前的调试信息,包括当前执行的代码行、调用栈、变量的值等。我们可以在调试窗口中查看各个变量的值,观察程序的执行流程是否符合预期。例如,可以查看某个 SQL 语句执行过程中变量的变化,分析查询优化的过程。

验证调试环境

为了验证调试环境是否搭建成功,我们可以进行一个简单的调试示例。比如,在 MySQL 的查询执行代码中设置断点,然后执行一个简单的 SQL 查询,如SELECT * FROM users;

启动调试后,程序会在断点处暂停。我们可以通过调试窗口查看查询执行过程中各个变量的状态,例如查询语句的解析结果、执行计划等。

逐步执行代码(使用调试窗口中的 “Step Over”、“Step Into”、“Step Out” 按钮),观察程序的执行流程。如果能够顺利地进行断点调试,并且能够正确查看变量的值和执行流程,那么说明调试环境搭建成功。

例如,在调试过程中,我们可以看到查询语句被解析成抽象语法树,然后根据优化规则生成执行计划,最终执行查询并返回结果。通过这样的调试,我们可以深入了解 MySQL 的内部机制,为后续的开发和优化工作提供有力支持。

我们找到名称为 mysqld 的选项,它就是 MySQL Server 启动的选项。可以先用该选项执行 MySQL数据库目录的初始化操作,生成对应的配置文件和用户名密码,然后再使用该选项来启动 MySQL Server。要注意,两个操作对应的参数不一样。

初始化的参数如下:

–initialize-insecure --user=mysql

然后再使用下面参数启动:

–user=mysql

最后使用登录命令进行登录,直接回车就可以,因为我们初始化的时候并没有设置密码

mysql -uroot -S /Users/shandian/CLionProjects/mysql-server/build_out/data/mysql.sock

然后我们就可以在 CLion 上打上断点,对 MySQL 进行调试了。

总结与拓展

搭建 MySQL 8.0.41 源码在 Mac 11.6 系统下,借助 CLion 2024.3.4、CMake 3.30.5 和 LLDB19.1.3 进行 Debug 环境的过程,虽然步骤较为繁琐,但每一步都至关重要。在这个过程中,需要特别注意各软件版本的兼容性,比如 CMake 版本与 CLion、MySQL 源码之间的适配,避免因版本不兼容导致构建失败。同时,配置 CMake 选项时,一定要仔细核对路径和参数,任何一个小的错误都可能引发后续构建和调试的问题。在构建项目过程中,网络问题可能会影响依赖库的下载,需要及时处理。

通过成功搭建这个调试环境,我们获得了深入探索 MySQL 内部机制的有力工具。建议读者在掌握了基本的调试技巧后,进一步探索 MySQL 的核心模块,比如存储引擎的实现、查询优化器的算法等。可以尝试修改源码,观察其对 MySQL 功能和性能的影响,从而加深对数据库原理和开发的理解。希望大家在 MySQL 源码调试的探索中不断取得新的成果,为数据库领域的研究和开发贡献自己的力量。

碰到的问题

1. ld: unknown option: -no_warn_duplicate_libraries

根据错误信息 ld: unknown option: -no_warn_duplicate_libraries,问题根源是 macOS 的 ld 链接器不支持 -no_warn_duplicate_libraries 选项。该选项可能由 MySQL 的 CMake 脚本在非 macOS 平台下添加,但在 macOS 上不兼容。以下是具体解决方案:
临时修复(快速验证)

# 进入构建目录
cd /Users/shandian/CLionProjects/mysql-server/build_out# 使用 sed 删除 -Xlinker -no_warn_duplicate_libraries 选项
sed -i '' 's/-Xlinker -no_warn_duplicate_libraries//g' build.ninja# 

重新编译

2 .std::bit_floor 未定义

在编译 MySQL 时遇到 std::bit_floor 未定义的错误,是因为你的编译器或标准库版本不支持 C++20 的 头文件中的 bit_floor 函数。以下是针对 macOS 环境的解决方案:

降级 MySQL 版本

git checkout 8.0  # 假设使用 Git 仓库
# 清理并重新编译
rm -rf build_out/*

3.无法从 archives.boost.io 下载 Boost 1.77.0 源码包

错误日志:

Applications/CLion.app/Contents/bin/cmake/mac/x64/bin/cmake -DCMAKE_BUILD_TYPE=Debug -DCMAKE_MAKE_PROGRAM=/Applications/CLion.app/Contents/bin/ninja/mac/x64/ninja -DDOWNLOAD_BOOST=1 -DWITH_BOOST=~/CLionProjects/mysql-server/boost -DCMAKE_BUILD_TYPE=Debug -DCMAKE_INSTALL_PREFIX=~/CLionProjects/mysql-server/build_out -DMYSQL_DATADIR=~/CLionProjects/mysql-server/build_out/data -DSYSCONFDIR=~/CLionProjects/mysql-server/build_out -DMYSQL_UNIX_ADDR=~/CLionProjects/mysql-server/build_out/data/mysql.sock -DMYSQL_MAINTAINER_MODE=false -G Ninja -S /Users/shandian/CLionProjects/mysql-server -B /Users/shandian/CLionProjects/mysql-server/build_out
-- Running cmake version 3.30.5
-- CMAKE_MODULE_PATH is /Users/shandian/CLionProjects/mysql-server/cmake
-- MySQL 8.0.41
-- Source directory /Users/shandian/CLionProjects/mysql-server
-- Binary directory /Users/shandian/CLionProjects/mysql-server/build_out
-- CMAKE_GENERATOR: Ninja
-- SIZEOF_VOIDP 8
-- DEFAULT_PLATFORM macos11.6
-- Packaging as: mysql-8.0.41-macos11.6-x86_64
-- Downloading boost_1_77_0.tar.bz2 to /Users/shandian/CLionProjects/mysql-server/boost
-- Download failed, error: 7;"Couldn't connect to server"
CMake Error at cmake/boost.cmake:234 (MESSAGE):You can try downloadinghttps://archives.boost.io/release/1.77.0/source/boost_1_77_0.tar.bz2manually using curl/wget or a similar tool
Call Stack (most recent call first):CMakeLists.txt:1586 (INCLUDE)

解决方案:
手动下载 Boost

步骤 1:下载 Boost 1.77.0
通过浏览器或命令行下载 Boost:

# 使用 curl 或 wget
curl -L -o ~/Downloads/boost_1_77_0.tar.bz2 https://sourceforge.net/projects/boost/files/boost/1.77.0/boost_1_77_0.tar.bz2/download
# 移动下载的文件
mv ~/Downloads/boost_1_77_0.tar.bz2 ~/CLionProjects/mysql-server/boost/

步骤2 :调整 CMake 配置
在 CLion 的 CMake 配置中移除 -DDOWNLOAD_BOOST=1,或显式设置为 0:

-DDOWNLOAD_BOOST=0

使用绝对路径指定 Boost

-DWITH_BOOST=/Users/shandian/CLionProjects/mysql-server/boost

清理并重新生成构建

rm -rf /Users/shandian/CLionProjects/mysql-server/build_out/*

4.MySQL 启动时 component_reference_cache.so 缺失

从其它地方拷贝了一个,放在以下目录

/Users/shandian/CLionProjects/mysql-server/build_out/lib/plugin/

5.修复 Unix Socket 锁文件创建失败

Could not create unix socket lock file ~/CLionProjects/mysql-server/build_out/data/mysql.sock.lock.

解决方法:
在 CMake 配置中替换 ~ 为绝对路径 /Users/shandian

-DMYSQL_DATADIR=/Users/shandian/CLionProjects/mysql-server/build_out/data \-DMYSQL_UNIX_ADDR=/Users/shandian/CLionProjects/mysql-server/build_out/data/mysql.sock

参考

原文链接:https://blog.csdn.net/qq_40161813/article/details/127823025

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/36598.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用码云搭建CocoaPods远程私有库

一、创建远程私有索引库 用来存放私有框架的详细描述信息.podspec文件 1. 创建私有库 假设码云上创建的私有库为repo-spec 2. 查看本地已存在的索引库 pod repo list 3. 将远程私有索引库添加到本地 pod repo add [https://gitee.com/jingluoguo/repo-spec.git](https://gi…

Devops之AWS:如何安装AWS CLI

AWS 命令行界面(AWS CLI)是一种开源工具,让我们能够使用命令行 Shell 中的命令与 AWS 服务进行交互。 安装步骤: 下载并运行AWS CLI的MSI安装程序: 点击如下的链接,即可下载MSI安装程序: htt…

docker需要sudo才能使用

一种方法是添加当前用户到docker组里去,当时添加的时候貌似是没问题的,但是现在又不可以了 产生的报错 ❯ docker images Cannot connect to the Docker daemon at unix:///home/ying/.docker/desktop/docker.sock. Is the docker daemon running?解决…

jmeter将返回的数据写入csv文件

举例说明,我需要接口返回体中的exampleid与todoid的数据信息(使用边界提取器先将其提取),并将其写入csv文件进行保存 使用后置处理器BeanShell 脚本实例如下 import java.io.*;// 设置要写入的文件路径 String filePath "…

在线教育网站项目第四步:deepseek骗我, WSL2不能创建两个独立的Ubuntu,但我们能实现实例互访及外部访问

一、说明 上一章折腾了半天,搞出不少问题,今天我们在deepseek的帮助下,完成多个独立ubuntu24.04实例的安装,并完成固定ip,实践证明,deepseek不靠谱,浪费我2个小时时间,我们将在下面实…

Apache Paimon 在抖音集团多场景中的优化实践

资料来源:火山引擎-开发者社区 本文将基于抖音集团内部两大业务的典型实时数仓场景,介绍Paimon在抖音集团内部的生产实践。 作者:李明、苏兴、文杰 抖音集团大数据工程师 目前抖音集团内部主要使用 Lambda 架构进行实时数仓建设,其…

PDF Reader Pro for Mac v4.9.0 PDF编辑/批注/OCR/转换工具 支持M、Intel芯片

PDF Reader Pro 是一款用户必备的集管理、编辑、转换、阅读功能于一体的专业的全能PDF阅读专家。快速、易用、强大,让您出色完成 PDF 工作。 应用介绍 PDF Reader Pro,一款功能齐全且强大的PDF阅读和编辑软件。支持PDF阅读、批注、PDF编辑、PDF格式转换…

HTML5与CSS3新特性详解

一、HTML5新特性 1.概述 HTML5 的新增特性主要是针对于以前的不足,增加了一些新的标签、新的表单和新的表单属性等。 这些新特性都有兼容性问题,基本是 IE9 以上版本的浏览器才支持,如果不考虑兼容性问题,可以大量使用这些新特…

shell 脚本搭建apache

#!/bin/bash # Set Apache version to install ## author: yuan# 检查外网连接 echo "检查外网连接..." ping www.baidu.com -c 3 > /dev/null 2>&1 if [ $? -eq 0 ]; thenecho "外网通讯良好!" elseecho "网络连接失败&#x…

Linux环境使用jmeter做性能测试

一、安装JDK,版本jdk1.8 1、下载压缩包到/jdk目录下解压 cd /jdk tar -zxvf jdk-8u241-linux-64.tar.gz 2、配置环境变量 在profile文件中末尾新增信息如下所示 vim /etc/profile export JAVA_HOME/usr/local/java/jdk/jdk1.8.0_221 export PATH$PATH:$JAVA_HOM…

巧用符号链接搬移C盘中的软件数据目录到其他盘

#工作记录 我们知道,在Windows11系统,有些软件是不能指定安装目录的,有些软件即使指定了安装目录可是在更新版本之后还是会安装到默认的C盘目录中(比如剪映),而且每次安装某些软件之后,这些软件…

Mysql的安装配置

目录 MySQL 简介 MySQL 的下载安装 mysql配置【默认以及下载好】 (1)配置环境变量 (2)修改配置文件 (3)以管理员身份运行cmd(一定要用管理员身份运行,不然权限不够) …

登山第二十梯:无人机实时自主探索——我是一只小小小鸟

文章目录 一 摘要 二 资源 三 内容 一 摘要 自主探索是无人机 (UAV) 各种应用的基本问题。最近,基于 LiDAR 的探索因其能够生成大规模环境的高精度点云地图而受到广泛关注。虽然点云本身就为导航提供了信息,但许多现有的勘探方…

基于FPGA轨道交通6U机箱CPCI脉冲板板卡

板卡简介: 本板为脉冲板,脉冲板主要执行CPU下达的指令,通过实现各种控制算法来调节PWM,然后输出光纤PWM信号来驱动变频器功率模块以达到控制电机的目的。 性能规格: 电源:DC5V;15V FPGA&…

一键批量txt转DWG,DWG转txt——插件实现 CAD c#二次开发

如下图,我们有大量dwg需要转为txt格式,或txt格式坐标需要转为dwg格式,此插件可一键完成一个文件夹下所有文件的转换。 插件使用方式 命令行输入: netload 加载此dll插件, 输入: dwg2txt 可将dwg转为t…

【Unity基础】Unity中角色动画的三种实现方式

在Unity中,角色动画有三种不同的实现方式:逐帧动画(Frame-by-Frame)、剪裁动画(Cutout)和骨骼动画(Skeletal),各自适用于不同的场景和需求。以下是它们的核心区别及特点&…

Flutter中Align的使用说明

又失业了,作为一个高龄Android程序员今年找工作真难呀。现在Flutter是必需技能了,所以最近在自学。所用书籍叫《Flutter实战》,如下 如今已看了100多页,发现这本书写得……有点赶吧,好几处讲得不清不楚,而关…

leetcode hot100(五)

11. 盛最多水的容器 给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。 找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。 返回容器可以储存的最大水量。 说明:你…

echarts+Vue2 自动轮播饼图

1、首先下载echarts,并且全局引入echarts 方法:从 npm 安装 npm install echarts 在 main.js 文件中全局引入 然后创建一个vue文件,名字随便起,比如 pieChart.vue,话不多说,直接上才艺:&…

自学软硬件第755 docker容器虚拟化技术

见字如面, 这里是AIGC创意人_竹相左边, 正在通过AI自学软硬件工程师,目标手搓可回收火箭玩具。 我很喜欢 《流浪地球 2》中 ,马兆:没有硬件支撑,你破解个屁。 写作背景 今天在剪视频,然后看…