在CentOS6.4中进行MySql5.7.17源代码安装详解

关键词:CentOS6.4 MySql5.7.17 源代码安装
本文分成两部分来讲MySQL源码安装。第一部分详细介绍安装步骤。第二部分介绍安装过程中遇到的问题如何解决。
第一部分:操作步骤

  1. 确认操作系统类型,这个关系到后续安装哪个版本的MySQL的。
    [root@localhost ~]# cat /etc/issue
    CentOS release 6.4 (Final)
    Kernel \r on an \m
  2. 确认操作系统位数
    [root@localhost ~]# getconf LONG_BIT
    64
  3. 在MySQL官网下载源码。
    通过源码编译的方式来安装。

    《在CentOS6.4中进行MySql5.7.17源代码安装详解》 MySQL官网选择合适版本

《在CentOS6.4中进行MySql5.7.17源代码安装详解》 点击相应版本下载

这两个都可以。区别就是第一个,需要自己在安装MySQL过程中下载Boost文件。我选择的是第一个。

  1. 预先安装依赖软件
    yum install -y gcc-c++ make cmake bison bison-devel ncurses-devel libaio-devel perl perl-Data-Dumper
  2. 创建MySQL用户和用户组
    先查看是否已经创建:
    cat /etc/passwd | grep mysql
    cat /etc/group | grep mysql
    没有创建则新建mysql用户以及用户组:
    groupadd mysql
    useradd -r -g mysql mysql
  3. 通过SecrureCRT上传到Linux主机/usr/local/tools目录里。
    tar -zxv -f mysql-5.7.17.tar.gz
  4. 安装boost库
    cd /usr/local/tools
    wget http://nchc.dl.sourceforge.net/project/boost/boost/1.59.0/boost_1_59_0.tar.gz
    mkdir /usr/local/boost
    cp /usr/local/tools/boost_1_59_0.tar.gz /usr/local/boost/boost_1_59_0.tar.gz
    cd /usr/local/boost
    tar -zxvf boost_1_59_0.tar.gz
  5. 创建MySQL安装目录和数据目录
    mkdir /usr/local/mysql
    mkdir /usr/local/mysql/data
  6. cmake安装MySQL
cd /usr/local/tools/mysql-5.7.17
cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DENABLED_LOCAL_INFILE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DMYSQL_USER=mysql \
-DMYSQL_TCP_PORT=3306 \
-DWITH_BOOST=/usr/local/boost
  1. 安装过程会持续一段时间,耐心等待编译完成,然后执行如下命令。
    make && make install
    本人大概等了50分钟,
  2. 安装完成之后修改/etc/my.cnf
    [mysqld]
    port = 3306
    basedir =/usr/local/mysql
    datadir =/usr/local/mysql/data
    log-error = /usr/local/mysql/data/error.log
    user = mysql
    tmpdir = /tmp
  3. 修改MySQL目录所有者
    chown -R mysql:mysql /usr/local/mysql
  4. 添加MySQL服务
    cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
  5. 初始化数据库
    /usr/local/mysql/bin/mysqld –initialize –user=mysql –basedir=/usr/local/mysql –datadir=/usr/local/mysql/data
    注:初始化后会生成默认密码,请记录下来
  6. 创建数据库及表
/usr/local/mysql/mysql-5.7.17/client/mysql_install_db \
--defaults-file=/etc/my.cnf \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data \
--user=mysql
  1. 启动MySQL
    service mysql start
  2. 开启MySQL
    /usr/local/mysql/bin/mysql -uroot -p

第二部分:问题及解决方法

  1. mysql登录不成功,不知道root账户的密码,如何解决。
    第一步,在 root 用户下,修改 my.cnf 文件,跳过密码直接登录。
    $ vi /etc/my.cnf
    [mysql]配置区域添加:
    skip-grant-tables
    $ service mysql restart
    此时可直接登录,然后修改密码。
    $ /usr/local/mysql/bin/mysql -uroot
    mysql> update user set authentication_string=password(‘自定义密码’) where user=’root’;
    mysql> quit
    第二步,登出 mysql,修改 my.cnf,去掉添加的 skip-grant-tables ,重启 mysqld 服务,使用新密码登录。

  2. mysql连接成功后,输入sql命令,报错You must SET PASSWORD before executing this statement

alter user 'root'@'localhost' identified by '自定义密码';
flush privileges;
  1. mysql无法启动(Table ‘mysql.plugin’ doesn’t exist)
    解决方案:初始化数据库
/usr/local/mysql/mysql-5.7.17/client/mysql_install_db \
--defaults-file=/etc/my.cnf \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data \
--user=mysql

对以下文章的作者致以感谢!
鹤立湘水http://www.cnblogs.com/xiangshui/p/5194990.html
Linux公社 http://www.linuxidc.com/Linux/2017-02/140133.htm

    原文作者:Beyond2050
    原文地址: https://www.jianshu.com/p/2c2a075a414a
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞