Mysql5.7编译调试(windows环境)

Mysql5.7编译调试(windows环境)

必备环境

为了防止出现不必要的麻烦,perl,cmake,Bison都直接安装在c盘,且目录不要有空格,最好是,如:c:/perl,c:/cmake, c:/bison

  1. OS:windows7 + VS2013
  2. mysql 源码(5.7.23)
  3. perl tool:ActivePerl-5.16.3.1604-MSWin32-x64-298023.msi
  4. Cmake:cmake-3.5.0-win32-x86.exe
  5. Bison:bison-2.4.1-setup.exe

为了验证成功,可以执行以下命令:

  1. where bison
  2. where cmake
  3. where perl

如果出现找不到,那就自己加path就行了

编译步骤

  1. 进入mysql的源码目录,创建编译文件目录,如cbuild(D:\Project\study\mysql-5.7.23\cbuild)
  2. 打开cmake(C:\CMake\bin\cmake-gui.exe),选择目录,然后点configure,选择自己的vs版本
  3. configure出现错误,需要下载boost
  4. 下载boost_1_59_0,下载后解压到相应目录,如:D:\Project\study\boost_1_59_0
  5. 重新修改Cmake,WITH_BOOST后面指定boost的目录
  6. 点击configure后,再点击generate,出现如下表示成功
  7. 用vs2013打开
  8. 为了减少错误信息,需要修改一些源码的编码方式,如下文件,修改的方法很简单,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 
  1. 找到sql\mysqld.cc中的test_lc_time_sz()函数,将其中的DBUG_ASSERT(0)改为DBUG_ASSERT(1)
  2. 编译过程中有free函数老报错,可以修改下名字,主要是plugin/keyring/buffer.h,plugin/keyring/buffer.cc,socket_events.cc
  3. 运行mysqld.exe --initialize-insecure,时间可能有点长(如果出现错误,看一下是不是data目录不存在,可以手动创建)
  4. 然后就可以运行mysqld.exe --console进行调试了

猜你喜欢

转载自www.cnblogs.com/muzhao/p/9759169.html