Mysql5.7编译调试(windows环境)
Mysql5.7编译调试(windows环境)
必备环境
为了防止出现不必要的麻烦,perl,cmake,Bison都直接安装在c盘,且目录不要有空格,最好是,如:c:/perl,c:/cmake, c:/bison
- OS:windows7 + VS2013
- mysql 源码(5.7.23)
- perl tool:ActivePerl-5.16.3.1604-MSWin32-x64-298023.msi
- Cmake:cmake-3.5.0-win32-x86.exe
- Bison:bison-2.4.1-setup.exe
为了验证成功,可以执行以下命令:
- where bison
- where cmake
- where perl
如果出现找不到,那就自己加path就行了
编译步骤
- 进入mysql的源码目录,创建编译文件目录,如cbuild(D:\Project\study\mysql-5.7.23\cbuild)
- 打开cmake(C:\CMake\bin\cmake-gui.exe),选择目录,然后点configure,选择自己的vs版本
- configure出现错误,需要下载boost
- 下载boost_1_59_0,下载后解压到相应目录,如:D:\Project\study\boost_1_59_0
- 重新修改Cmake,WITH_BOOST后面指定boost的目录
- 点击configure后,再点击generate,出现如下表示成功
- 用vs2013打开
- 为了减少错误信息,需要修改一些源码的编码方式,如下文件,修改的方法很简单,editplus工具打开以unicode编码保存
源码目录\strings\ctype-czech.c
源码目录\strings\ctype-latin1.c
源码目录\strings\decimal.c
源码目录\mysys\thr_mutex.c
源码目录\storage\innobase\include\ut0mem.h
源码目录\sql\sql_locale.cc
- 找到sql\mysqld.cc中的test_lc_time_sz()函数,将其中的DBUG_ASSERT(0)改为DBUG_ASSERT(1)
- 编译过程中有free函数老报错,可以修改下名字,主要是plugin/keyring/buffer.h,plugin/keyring/buffer.cc,socket_events.cc
- 运行mysqld.exe --initialize-insecure,时间可能有点长(如果出现错误,看一下是不是data目录不存在,可以手动创建)
- 然后就可以运行mysqld.exe --console进行调试了