美文网首页mysqlMySQL
在CentOS6.4中进行MySql5.7.17源代码安装详解

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

作者: Beyond2050 | 来源:发表于2017-02-26 16:58 被阅读27次

    关键词: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官网下载源码。
      通过源码编译的方式来安装。


      MySQL官网选择合适版本
    点击相应版本下载

    这两个都可以。区别就是第一个,需要自己在安装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

    相关文章

      网友评论

        本文标题:在CentOS6.4中进行MySql5.7.17源代码安装详解

        本文链接:https://www.haomeiwen.com/subject/pxtowttx.html