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:Projectstudymysql-5.7.23cbuild)
  2. 打开cmake(C:CMakeincmake-gui.exe),选择目录,然后点configure,选择自己的vs版本
  3. configure出现错误,需要下载boost
  4. 下载boost_1_59_0,下载后解压到相应目录,如:D:Projectstudyoost_1_59_0
  5. 重新修改Cmake,WITH_BOOST后面指定boost的目录
  6. 点击configure后,再点击generate,出现如下表示成功
  7. 用vs2013打开
  8. 为了减少错误信息,需要修改一些源码的编码方式,如下文件,修改的方法很简单,editplus工具打开以unicode编码保存
源码目录stringsctype-czech.c
源码目录stringsctype-latin1.c
源码目录stringsdecimal.c
源码目录mysys	hr_mutex.c
源码目录storageinnobaseincludeut0mem.h
源码目录sqlsql_locale.cc
  1. 找到sqlmysqld.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进行调试了

原文地址:https://www.cnblogs.com/muzhao/p/9759169.html