软硬件环境
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 Sourcedev.mysql.com4 MySQL Source-Configuration Optionsdev.mysql.com
下载 boost 软件地址,该网址有不同版本的boostBoost C++ Librariessourceforge.net