Macos 编译运行调试Mysql源代码
准备编译工具Clion
下载地址
工具是macos用的系统
下载mysql源码
下载boost
前期准备工作
- MySQL源码目录:
/Users/baiyuliuguang/Documents/study/mysql/mysql-8.0.4-rc- MySQL编译工作目录[basedir]:
/Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc- MySQL编译后的数据目录[datadir]:
/Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc/data
这些目录其中有的是自己创建的,我展示的是我绝对路径,大家可以放在其他位置,只要配置的时候配置好就行了。
搭建Mysql
编译Mysql
- 第一步进入源码目录
cd /Users/baiyuliuguang/Documents/study/mysql/mysql-8.0.4-rc/
- 第二步cmake
cmake \
-DCMAKE_INSTALL_PREFIX=/Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc \
-DMYSQL_DATADIR=/Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc/data \
-DSYSCONFDIR=/Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc \
-DMYSQL_UNIX_ADDR=/Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc/data/mysql.sock \
-DWITH_DEBUG=1 \
-DDOWNLOAD_BOOST=1 -DWITH_BOOST=/Users/baiyuliuguang/Documents/study/mysql/boost_1_65_0

- 第三部 make
make -j 4

- 第四步 安装
make install -j 4

- 第五步 初始化数据库
cd /Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc/bin
2../mysqld --basedir=/Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc --datadir=/Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc/data --initialize-insecure --user=baiyuliuguang

配置Clion
导入MySQL源码项目
选择路径:/Users/baiyuliuguang/Documents/study/mysql/mysql-8.0.4-rc, 导入后,clion会默认用系统自动的makefile文件make一遍,如果系统自带的boost不是1.65.0的话,会有报错,不用处理,接下来cmake配置后,不会有这问题;
TIP
选择cmake项目
cmake 配置
clion -> Preferences -> Build,Execution,Deployment -> CMake

-DCMAKE_INSTALL_PREFIX=/Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc \ -DMYSQL_DATADIR=/Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc/data \ -DSYSCONFDIR=/Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc \ -DMYSQL_UNIX_ADDR=/Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc/data/mysql.sock \ -DWITH_DEBUG=1 \ -DDOWNLOAD_BOOST=1 -DWITH_BOOST=/Users/baiyuliuguang/Documents/study/mysql/boost_1_65_0
- 配置debug

点击Edit Configurations
// 1 中的Target和Executable 都选择mysqld
// 2 中写一个Name,由于上一步已经写了mysqld,这里再次写mysqld,提示已经有应用是mysqd了,这里写的是mysqld2
// 3 中写的是
--defaults-file=/Users/baiyuliuguang/Documents/study/mysql/etc/my.cnf
--basedir=/Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc
--datadir=/Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc/data
// 4 中是MySQL编译后的Home路径
其中配置my.cnf
my.cnf的文件内容如下
[mysqld]
port = 3306
socket = /Users/baiyuliuguang/Documents/study/mysql/tmp/mysql.sock
skip-external-locking
skip-grant-tables
key_buffer_size = 16K
default-storage-engine=INNODB
character-set-server=utf8
pid-file=/Users/baiyuliuguang/Documents/study/mysql/mysqld/mysqld.pid
[mysqld_safe]
pid-file=/Users/baiyuliuguang/Documents/study/mysql/mysqld/mysqld.pid
[client]
default-character-set=utf8
其中没有的文件夹要自己创建

- 至此所有的都配置好了,点击debug臭虫,就可以启动MySQL。

调试
- 找到
sql/sql_parse.cc的do_command函数,设置断点

- 登录MySQL,需要进入
/Users/baiyuliuguang/Documents/study/mysql/mysql_data/mysql-8.0.4-rc/bin下面执行, 直接enter回车即可,root初始化密码为空密码mysql -uroot -h127.0.0.1 -P3306 -p

遇到的问题
如果遇到已经有mysql占用端口
记得关掉这边的myql服务


Macos 编译运行调试Mysql源代码的更多相关文章
- 在windows下使用vs2013编译和调试mysql源代码
1. 准备工作 1)OS:win10 + VS2013 2)mysql 源码(windows版):mysql-5.6.25.zip 3)perl tool:ActivePerl-5.16.3.1604 ...
- vscode配置编译运行调试C/C++文件-windows环境
在windows环境下,编译运行小文件的C/C++环境 软件准备: vscode mingw64(官网下特别慢,可以在devc++安装软件里中找,放到全局变量中) 插件下载: Run Code C/C ...
- Sublime-Text macOS 编译运行armadillo
{ "cmd" : ["g++ -std=c++14 -Wall -larmadillo -framework Accelerate ${file_name} -o ${ ...
- Win7+VS2010:mysql 源代码编译与调试
win7+vs2010源代码编译mysql 近期因为在实习,工作重点在于一些数据库的开发,为了更好的理解数据库的实现机制.眼下萌生了要研究一下mysql数据库源代码的想法.那么好吧,说干就干.首先我们 ...
- Xamarin 跨移动端开发系列(01) -- 搭建环境、编译、调试、部署、运行
如果是.NET开发人员,想学习手机应用开发(Android和iOS),Xamarin 无疑是最好的选择,编写一次,即可发布到Android和iOS平台,真是利器中的利器啊!好了,废话不多说,就开始吧, ...
- MYSQL源代码编译的变动
Mysql的安装,对于mysql不同版本号的mysql源代码编译方式不一样 5.6.2的版本号開始编译方式已经由 configure 变成了cmake方式 ,相关的新的 编译方式在mysql官网已经提 ...
- EditPlus远程编辑、语法高亮、编译运行源代码设置
最近写代码的过程中,除了写Java时用的Eclipse.在Linux下编辑的Vi之外,有时也会用EditPlus打开一些文件,如配置文件.日志文件.脚本等.个人觉得EditPlus在很多场景下比较好用 ...
- 如何编译和调试Python内核源码?
目录 写在前面 获取源代码 源代码的组织 windows下编译CPython 调试CPython 小结 参考 博客:blog.shinelee.me | 博客园 | CSDN 写在前面 如果对Pyth ...
- 在ASP.NET 5项目中使用和调试外部源代码包
(此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) 题记:由于在ASP.NET 5中,项目依赖都是通过"包"来引用,所以使用 ...
随机推荐
- 【目标检测】:SPP-Net深入理解(从R-CNN到SPP-Net)
一. 导论 SPP-Net是何凯明在基于R-CNN的基础上提出来的目标检测模型,使用SPP-Net可以大幅度提升目标检测的速度,检测同样一张图片当中的所有目标,SPP-Net所花费的时间仅仅是RCNN ...
- “随手记”开发记录day16
今天先对前两天增加的“修改”功能进行测试.然后进行功能的明显划分,丰富账单的添加和显示方法.
- NIO(三):Selector选择器
一.堵塞式与非堵塞式 在传统IO中,将数据由当前线程从客户端传入服务端,由服务端的内核进行判断传过来的数据是否合法,内核中是否存在数据. 如果不存在数据 ,并且数据并不合法,当前线程将会堵塞等待.当前 ...
- C# ASP response.write()弹出提示框后页面布局被打乱
发现在使用了response.write后样式发生了变化,位置和字体都不正确.Response.Write("<script>alert(')</script>&qu ...
- day3 基本语句
代码缩进为一个tab键 就是四个空格 断点 在代码首行前空白处,双击 然后点右上角臭虫 然后点下面箭头朝下的 1.if 语句 if 判断条件: ...
- kafka-clients 1.0 高阶API消费消息(未完)
消费消息的请求(按序) org/apache/kafka/common/requests/RequestHeader org/apache/kafka/common/requests/ApiVersi ...
- Core + Vue 后台管理基础框架9——统一日志
1.背景 前阵子有园友留言,提到日志相关的东西,同时,最近圈子里也有提到日志这个东西.一个充分.集中的统一日志平台还是很有必要的,否则系统出问题了只能靠猜或者干瞪眼.何谓充分,日志记录满足最低要求.出 ...
- Linked server的一个问题
好久没有写新的博客,主要是很久没有什么动力和需求来写程序.虽然也不是一点没写,但都缺乏技术含量,没什么可说的. 前两天碰到一个关于linked server的问题.本地的sql server里,通过l ...
- Android 找不到所标识的资源 java.lang.NoSuchFieldError: No static field XXX of type I in class Lcom/XX/R$id
报错: java.lang.NoSuchFieldError: No static field XXX of type I in class Lcom/XXX/R$id; or its supercl ...
- OpenJDK和OracleJDK的区别
在2006年11月13日的JavaOne大会上,Sun公司(当时还没被收购)宣布计划要把Java开源,在随后的一年多时间内,它陆续地将JDK的各个部分在GPL v2(GNU General Publi ...