mysql source code_制作 Mysql 8.0 from source code

软硬件环境

MacOS High Sierra, Version: 10.13.6

make version: GNU Make 3.81

Xcode version: 9.4.1

boost version: boost_1_68_0.tar.bz2

编译 boost (一个C++的库,mysql的编译需要该库)

--prefix= Install architecture independent files here.

Default; C:\Boost on Win32

Default; /usr/local on Unix. Linux, etc.

编译 Mysql 8.0

cmake . -G Xcode

-DWITH_DEBUG=1

-DCMAKE_INSTALL_PREFIX=/Users/zhangminglei/project/mysql-server/work

-DMYSQL_DATADIR=/Users/zhangminglei/project/mysql-server/data

-DWITH_INNOBASE_STORAGE_ENGINE=1

-DWITH_ARCHIVE_STORAGE_ENGINE=1

-DWITH_ARCHIVE_STORAGE_ENGINE=1

-DWITH_READLINE=1

-DWITH_LIBWRAP=0

-DMYSQL_UNIX_ADDR=/tmp/mysql.sock

-DENABLED_LOCAL_INFILE=1

-DENABLED_LOCAL_INFILE=1

-DENABLE_DOWNLOADS=1

-DDOWNLOAD_BOOST=1

-DWITH_BOOST=/usr/local/Cellar/boost/1.68.0_1

-DFORCE_INSOURCE_BUILD=1

在启动 mysql 的过程中,会发现无法创建 sock file 文件, 此时,去错误提示下把 /usr/local/opt下的 mysql 文件夹重名为 mysqls, 然后再kill mysql 进程,即可解决该问题,不然会一直重启mysql进程从而导致自己的编译的mysql无法创建 socket file,当然该解决方案比较 hack,目前也不影响别的mysql使用,所以先这样解决。

需要去自己编译生成的mysql下去执行,该目录为 -DCMAKE_INSTALL_PREFIX 指定,为安装的基本目录。mysql 的安装目录mysql 的数据目录,比如一些binlog文件

./mysql -uroot -p660202

然后用用 ps (process status) 进程查看运行的mysql服务 (输出已经简化)

ps aux | grep mysql

25577 /Users/zhangminglei/project/mysql-server/runtime_output_directory/Debug/mysqld

此时,就可以进行mysql的debug源码了。

比如我要debug 如下的sql语句:

select 3 div 10; 输入该 sql 语句后,可以发现此时shell进程被hang住。

如下就可以进行一步一步的debug mysql 源码了。

参考资料1 Installing MySQL from Source​dev.mysql.com4 MySQL Source-Configuration Options​dev.mysql.com

下载 boost 软件地址,该网址有不同版本的boostBoost C++ Libraries​sourceforge.net

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值