• 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进行调试了

  • 相关阅读:
    GateWay的简单使用
    SpringCloud项目注册到Nacos
    Hystrix整合Gateway
    Nginx配置socket.io集群
    windows搭建git服务
    解决gitLab上新建分支,idea中找不到对应分支问题
    mybatis mapper.xml的特殊操作符
    Chrome添加Axure RP插件
    idea Tomcat部署时没有update classes and resources
    缓存穿透,缓存击穿,缓存雪崩解决方案分析【转载】
  • 原文地址:https://www.cnblogs.com/muzhao/p/9759169.html
Copyright © 2020-2023  润新知