zoukankan      html  css  js  c++  java
  • ubuntu 14.04 源码编译mysql-5.7.17

    环境为 Ubuntu 12.04 64 位的桌面版

    编译的mysql 版本为 5.7.18

    首先需要安装一下依赖包

    sudo apt-get install libncurses5-dev cmake chkconfig

    创建用户组和用户 mysql

    groupadd  mysql
    useradd -r -g mysql -s /bin/bash mysql -d /home/mysql -m

    创建mysql 的目录

    cd /home/
    mkdir mysql
    cd mysql/
    mkdir data
    mkdir log
    chmod -R 777 /home/mysql

    下载boost 库,从mysql 的cmake 文件中,貌似它依赖的boost 1.59.0 版本的库,所以直接download boost 源码

    wget https://nchc.dl.sourceforge.net/project/boost/boost/1.59.0/boost_1_59_0.tar.gz

    解压boost 源码库

    mkdir -p /root/source/Boost ; 
    cd /root/source/Boost ; 
    mv /mnt/boost_1_59_0.tar.gz ./ ; 
    tar -zxvf ./boost_1_59_0.tar.gz ; 

    创建一个build的目录,为后面编译做准备

    mkdir build

    如果大家想对这个编译环境做gdb 源码研读,那样作者建议大家修改一下编译的配置项,因为默认情况下,编译是打开了“编译优化”选项,导致跟踪代码时,非常的混乱,解决的方法是打开cmake的配置文件,将-O3 的选项删除

    vi cmake/build_configurations/compiler_options.cmake

    然后查找 "CMAKE_C_FLAGS_RELWITHDEBINFO" 和 "CMAKE_CXX_FLAGS_RELWITHDEBINFO" 两个关键字,将 "-O3" 删除

    例如在84行,原来是

    SET(CMAKE_CXX_FLAGS_RELWITHDEBINFO "-O3 ${COMMON_CXX_FLAGS}")

    那么删除后,变成

    SET(CMAKE_CXX_FLAGS_RELWITHDEBINFO " ${COMMON_CXX_FLAGS}")

    如此类推,当然,这个步骤并非必须,大家如果希望程序未来运行速度快一点,就按照默认就好了。

    编译debug 模式,除了以上方法,也可以在cmake 生成编译文件时,增加一个 -DCMAKE_BUILD_TYPE=Debug 参数

    进入到build 的目录,生成mysql 的安装文件

    cd /opt/mysql-5.6.23/build
    sudo cmake ../ 
    -DCMAKE_INSTALL_PREFIX=/usr/local/mysql 
    -DMYSQL_UNIX_ADDR=/tmp/mysql.sock 
    -DDEFAULT_CHARSET=utf8 
    -DDEFAULT_COLLATION=utf8_general_ci 
    -DWITH_EXTRA_CHARSETS:STRING=utf8,gbk 
    -DWITH_MYISAM_STORAGE_ENGINE=1 
    -DWITH_INNOBASE_STORAGE_ENGINE=1 
    -DWITH_READLINE=1 
    -DENABLED_LOCAL_INFILE=1 
    -DMYSQL_DATADIR=/home/mysql/data 
    -DWITH_BOOST=/root/source/Boost/boost_1_59_0 
     

    经过测试发现,如果在Linux 中生成 Makefile 文件时,DEFAULT_CHARSET 参数只指定 “utf8”,则编译后的mysql 可执行文件不能够支持gbk 字符集。

    经过验证,如果在Linux中生成Makefile时,采用以下命令,则能够同时gbk和utf8。

    sudo cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql 
    -DMYSQL_UNIX_ADDR=/tmp/mysql.sock 
    -DDEFAULT_CHARSET=utf8 
    -DDEFAULT_COLLATION=utf8_general_ci 
    -DWITH_EXTRA_CHARSETS:STRING=utf8,gbk 
    -DWITH_MYISAM_STORAGE_ENGINE=1 
    -DWITH_INNOBASE_STORAGE_ENGINE=1 
    -DWITH_READLINE=1 
    -DENABLED_LOCAL_INFILE=1 
    -DMYSQL_DATADIR=/home/mysql/data 
    -DWITH_BOOST=/root/software/mysql-5.7.18/boost/boost_1_59_0

    编译安装mysql

    make && make install

    部署mysql服务

    cd /usr/local/mysql/ ; 
    cp support-files/my-default.cnf ./my.cnf ; 
    cp support-files/mysql.server ./mysqld ;

    将 mysqld 文件 拷贝到 /etc/init.d 目录,为了下面为操作系统添加一个 service 服务

    cp /usr/local/mysql/mysqld /etc/init.d/

    添加一个mysqld 的service 服务

    update-rc.d mysqld defaults

    随便说一下,如果删除这个mysqld 服务,可以执行以下命令

    update-rc.d mysqld remove

    如果是想设置开机自启动,可以参考 sysv-rc-conf 命令

    初始化一下 mysql 的data 目录,初始化之后,会在屏幕上输出一个临时的密码,但是由于我们拥有mysql 的更高权限,所以可以忽略它,通过其他方式来修改root 密码。

    /usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/home/mysql/data

    启动mysql 无鉴权服务

    bin/mysqld_safe --user=mysql --skip-grant-tables --skip-networking &

    登陆mysql shell,设置一个root 密码

    /usr/local/mysql/bin/mysql -uroot
    SQL> update mysql.user set authentication_string=PASSWORD('mysql') where user='root';

    停止刚才的mysql 服务,然后正常启动mysql 服务

    service mysqld stop;
    service mysqld start;

    再使用mysql shell 登陆

    /usr/local/mysql/bin/mysql -uroot -pmysql

    还需要再设置一次密码,就能够正常访问

    mysql> set password= password('mysql');

    在 mysql 上创建一个database,名为"foo",并且指定字符集为“utf8”

    CREATE DATABASE IF NOT EXISTS foo DEFAULT CHARSET utf8 COLLATE utf8_general_ci;

    如果希望创建的database 字符集为 “gbk”,则命令如下

    create database if not exists DATABASENAME DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;

    如果希望mysql 服务可以允许其他客户端远程登陆以 root 用户登陆进来,需要执行以下命令

    GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'mysql' WITH GRANT OPTION;

    mysql 是指登陆的密码,用户可以根据自己的需要修改,这里我只是用习惯性的填写为 “mysql” 而已

    通过源码编译、安装的mysql服务,默认配置文件my.cnf 在 /etc/mysql/my.cnf 目录下。

    mysql 服务的运行日志默认在 /var/log/mysql/error.log 路径下 

    配置mysql 

    参考博客:

    https://blog.phpha.com/archives/1685.html

    https://dev.mysql.com/doc/refman/5.7/en/installing-source-distribution.html

    http://xiaorui.cc/2016/01/20/mac%E4%B8%8B%E5%AE%89%E8%A3%85mysql5-7%E9%81%87%E5%88%B0%E9%BB%98%E8%AE%A4%E5%AF%86%E7%A0%81%E7%9A%84%E5%A4%A7%E5%9D%91/

    http://blog.csdn.net/xitong2012/article/details/7282448

  • 相关阅读:
    SSP状态寄存器SSPSTAT
    【PIC学习第18例】PIC16F877A 内部EEPROM读写实验
    批量去除flv专辑的片头
    .Net并行库介绍——Task(1)
    一个下载游戏封面的站点
    一个猜数字的小游戏
    RamDisk加速Windows 7?
    .Net并行库介绍——Task(2)
    数独的自动出题算法
    Live Messenger 2009登陆错误的解决方法
  • 原文地址:https://www.cnblogs.com/chenfool/p/4350763.html
Copyright © 2011-2022 走看看