zoukankan      html  css  js  c++  java
  • 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进行调试了

  • 相关阅读:
    from...import...导入模块
    import 导入模块
    模块介绍
    面向过程编程
    生成器表达式
    maven打包项目到nexus私服
    Centos安装solr-5.5.5.tgz
    记录一个spring框架搭建的错误
    dubbo、zookeeper和spring整合
    Centos安装配置weblogic
  • 原文地址:https://www.cnblogs.com/muzhao/p/9759169.html
Copyright © 2011-2022 走看看