当前位置: 首页 > article >正文

解锁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 调试器
      • 启动调试
      • 验证调试环境
    • 总结与拓展

解锁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 的内部机制,为后续的开发和优化工作提供有力支持。

总结与拓展

搭建 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 源码调试的探索中不断取得新的成果,为数据库领域的研究和开发贡献自己的力量。

相关文章:

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

文章目录 解锁MySQL 8.0.41源码调试:Mac 11.6CLion 2024.3.4实战指南前期准备环境搭建详细步骤安装 CLion安装 CMake 3.30.5准备 MySQL 8.0.41 源码配置 CMake 选项构建 MySQL 项目 调试环境配置与验证配置 LLDB 调试器启动调试验证调试环境 总结与拓展 解锁MySQL 8…...

celery入门

按照Celery 官方文档,用 Django Celery Redis 写的一个简单项目 如需转载,标记出处 环境准备 1. 安装依赖 pip install django celery redis 创建 Django 项目 1. 创建 Django 项目和 APP django-admin startproject myproject cd myproject python …...

关于xcode Project navigator/项目导航栏的一些说明

本文基于 xcode12.4 版本做说明 首先要明确一点,导航栏这里展示的并不是当前工程在电脑硬盘中的文件结构,它展示的是xxxxxx.xcodeproj/project.pbxproj文件(后文简.pbxproj文件)中的内容。我们在导航栏中的操作就是修改该文件,有些操作会修…...

深度解析扣减系统设计:从架构到实践

背景 在当今数字化业务蓬勃发展的时代,扣减系统在众多业务场景中扮演着关键角色。无论是电商平台的库存扣减,还是金融领域的资金扣减、积分系统的积分扣减,一个高效、可靠且数据一致的扣减系统都是业务稳健运行的基石。本文将深入探讨扣减系…...

视觉定位项目中可以任意修改拍照点位吗?

修改拍照点位不是那么简单 1. 背景2. 修改拍照点位意味着什么?3. 如何解决这个问题? 1. 背景 在视觉定位的项目中,会遇到这么一种情况:完成三步(9点标定,旋转中心标定,示教基准)之…...

深度学习常用操作笔记

深度学习常用操作笔记 指令报错cannot import name Config from mmcvImportError: cannot import name print_log from mmcvImportError: cannot import name init_dist from mmengine.runnerWARNING: Retrying (Retry(total4, connectNone, readNone, redirectNone, statusNon…...

C++学习内存管理

1.概念的介绍 总括: 1. 栈(Stack) 存储内容: 局部变量(包括函数参数、非静态局部变量)。 函数调用的上下文信息(如返回地址、寄存器状态等)。 特点: 内存由编译器自动…...

git使用。创建仓库,拉取分支,新建分支开发

文章目录 安装 git自己新建仓库,进行代码管理合作开发的流程拉去主分支代码查看本地分支的状态查看远程分支查看远程的仓库信息本地分支切换切换并创建分支提交代码 made by NJITZX git 是一个版本控制工具,真正开发项目中是多个人开发一个项目的&#…...

itsdangerous加解密源码分析|BUG汇总

这是我这两天的思考 早知道密码学的课就不旷那么多了 纯个人见解 如需转载,标记出处 目录 一、官网介绍 二、事例代码 源码分析: 加密函数dump源码使用的函数如下: 解密 ​编辑 ​编辑 关于签名: 为什么这个数字签名没有…...

常见限流算法及实现

1. 固定窗口计数器(Fixed Window Counter) 原理:在固定时间窗口(如1分钟)内统计请求数,超过阈值则拒绝后续请求。优点:实现简单,内存占用低。缺点:存在窗口切换时的流量…...

计算机操作系统进程(4)

系列文章目录 第二章:进程的描述与控制 文章目录 系列文章目录前言一、临界区的概念和描述:二、硬件同步机制: 1.关中断2.利用Test-and-Set指令实现互斥3.利用Swap指令实现进程的互斥 总结 前言 上一篇我们仅仅讲了一点关于线程同步的概念&a…...

编程题《牛牛的链表删除》的python可以用非链表的方式

描述 牛牛从键盘输入了一个长度为 n 的数组,把这个数组转换成链表然后把链表中所有值是 x 的节点都删除。 输入描述: 第一行输入两个正整数 n 和 x 表示数组的长度和要删除的链表节点值 x 。 第二行输入 n 个正整数表示数组中每个元素的值。 输出描述&am…...

Certbot实现SSL免费证书自动续签(CentOS 7版 + Docker部署的nginx)

前置安装,可参考Certbot实现SSL免费证书自动续签(CentOS 7 nginx/apache) 如果是通过 Docker 运行 Nginx, certbot 无法直接检测到本地的 Nginx 配置。解决方案是 使用 standalone 模式 或 挂载 Webroot 方式获取 SSL 证书&…...

C++|构造函数和析构函数

一、构造函数 构造函数是一种特殊的成员函数,主要用于创建对象时对对象进行初始化操作,即专门用于构造新对象,并赋值对象的成员数据。 在 C 里,构造函数的名称和类名相同,并且没有返回类型。当创建类的对象时&#x…...

AI日报 - 2025年3月17日

🌟 今日概览(60秒速览) ▎🤖 AGI突破 | GPT-o1在卡内基梅隆大学数学考试中获满分,展示AI数学能力新高度 成本仅5美分/题,推理速度不到1分钟 ▎💼 商业动向 | Figure推出BotQ机器人制造设施&…...

不像人做的题————十四届蓝桥杯省赛真题解析(上)A,B,C,D题解析

题目A:日期统计 思路分析: 本题的题目比较繁琐,我们采用暴力加DFS剪枝的方式去做,我们在DFS中按照8位日期的每一个位的要求进行初步剪枝找出所有的八位子串,但是还是会存在19月的情况,为此还需要在CHECK函数…...

JavaScript 中 call 和 apply 的用法与区别

文章目录 前言一、 call 方法1.1 基本用法1.2 传递多个参数 二、apply 方法2.1 基本用法2.2 传递数组参数 三、call 和 apply 的区别四、实际应用场景4.1 借用方法4.2 继承与构造函数 五、总结 前言 在 JavaScript 中,call 和 apply 是两个非常重要的函数方法&…...

go程序调用k8s pod副本的名称IP手动赋值给configmap的参数

1、创建configmap --- apiVersion: v1 data:config.yaml: >-# config.yamlEtcd:Endpoints:- "etcd-server:2379"Username: ""Password: ""Exchanges:#- Name: "Binance"# Symbol: "BTCUSDT"# WSUrl: "wss://fstr…...

面试系列|蚂蚁金服技术面【1】

哈喽,大家好!今天分享一下蚂蚁金服的 Java 后端开发岗位真实社招面经,复盘面试过程中踩过的坑,整理面试过程中提到的知识点,希望能给正在准备面试的你一些参考和启发,希望对你有帮助,愿你能够获…...

使用傅里叶变换测量声卡的频率失真

文章目录 一、说明二、关于声卡的技术详述三、实验代码获取四、结论 一、说明 假如我希望使用我的声卡来模拟软件无线电,利用声音而不是射频信号。我的声卡能胜任这项任务吗?本文将研究一种技术来找出答案。另外,需要了解音频技术的读者也可…...

Selenium 自动化测试学习总结

大概了解一下即可,现在主要用的自动化工具是 playWright,它可以录制操作。 selenium是老款自动化测试工具,仍有很多可取之处。 安装: pip install selenium即可。然后下载浏览器的驱动包,注意不是浏览器!…...

【HTML5】01-HTML摆放内容

本文介绍HTML5摆放标签的知识点。 目录 1. HTML概念 2. HTML骨架 3. 标签的关系 4. 标题标签 5. 段落标签 6. 换行和水平线 7. 文本格式化标签 8. 图像标签 图像 - 属性 9. 路径 相对路径 绝对路径 10. 超链接标签 11. 音频标签 12. 视频标签 1. HTML概念 HTM…...

内存管理:

我们今天来学习一下内存管理: 1. 内存分布: 我们先来看一下我们下面的图片: 这个就是我们的内存,我们的内存分为栈区,堆区,静态区,常量区; 我们的函数栈帧开辟消耗的内存就是我们…...

设计模式使用Java案例

代码设计要有可维护性,可复用性,可扩展性,灵活性,所有要使用设计模式进行灵活设计代码 创建型 简单工厂模式(Simple Factory) 简单工厂模式(Simple Factory Pattern)是一种创建型…...

Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现与实战指南

Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现与实战指南 一、核心概念对比 1. 本质区别 维度过滤器(Filter)拦截器(Interceptor)规范层级Serv…...

模运算的艺术:从基础到高阶的算法竞赛应用

在算法竞赛中,模运算(取模运算)是一个非常重要的概念,尤其在处理大数、防止溢出、以及解决与周期性相关的问题时。C 中的模运算使用 % 运算符,但它的行为和使用场景需要特别注意。 1. 模运算的基本概念 模运算是指求一…...

Java 并发编程——Java BIO NIO Socket编程

参考Java 并发编程——Java BIO NIO Socket编程 BIO:阻塞式编程模型 Socket 服务端编程Socket 客户端编程 NIO:非阻塞式编程模型 NIO 介绍Java 中 NIO 非阻塞式与前面 BIO 阻塞式的区别Java NIO类库包含以下三个核心组件ServerSocketChannel 服务端编程…...

ST电机库电流采样 三电阻单ADC

一、概述 下图是三电阻采样的电路结构 其中流过三相系统的电流I1、I2、I3遵循以下关系: 因此,为了重建流过普通三相负载的电流,在我们可以用以上公式计算的情况下,只需要对三相中的两相进行采样即可。 STM32的ADC可以很灵活的配置成同步采集两路ADC数据,…...

【网络】什么是 IHL(Internet Header Length,首部长度)TTL(Time To Live,生存时间)?

在 IPv4 数据报文中,IHL(Internet Header Length,首部长度)、TTL(Time To Live,生存时间) 和 TIL 涉及到 IP 数据包的结构和生命周期。以下是对它们的详细解释: 📌 1. IH…...

现代密码学 | 具有保密和认证功能的安全方案

1.案例背景 1.1 2023年6月,微软云电子邮件泄露 事件描述: 2023年6月,属于多家美国政府机构的微软云电子邮件账户遭到非法入侵,其中包括了多位高级政府官员的电子邮件。据报道,美国国务院的10个邮件账户中共有6万封电…...