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

17 篇文章 0 订阅
2 篇文章 0 订阅

关键词:CentOS6.4 MySql5.7.17 源代码安装

本文分成两部分来讲MySQL源码安装。第一部分详细介绍安装步骤。第二部分介绍安装过程中遇到的问题如何解决。

1、操作步骤

1.1、确认操作系统类型

这个关系到后续安装哪个版本的MySQL的。

[root@localhost ~]# cat /etc/issue

CentOS release 6.4 (Final)

Kernel \r on an \m

1.2、确认操作系统位数

[root@localhost ~]# getconf LONG_BIT

64

1.3、在MySQL官网下载源码。

通过源码编译的方式来安装。

MySQL官网选择合适版本

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

1.4、预先安装依赖软件

yum install -y gcc-c++ make cmake bison bison-devel ncurses-devel libaio-devel perl perl-Data-Dumper

1.5、创建MySQL用户和用户组

先查看是否已经创建:

cat /etc/passwd | grep mysql

cat /etc/group | grep mysql

没有创建则新建mysql用户以及用户组:

groupadd mysql

useradd -r -g mysql mysql

通过SecrureCRT上传到Linux主机/usr/local/tools目录里。

tar -zxv -f mysql-5.7.17.tar.gz

1.6、安装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

​

1.7、创建MySQL安装目录和数据目录

mkdir /usr/local/mysql

mkdir /usr/local/mysql/data

1.8、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

安装过程会持续一段时间,耐心等待编译完成,然后执行如下命令。

make && make install

本人大概等了50分钟,

1.9、安装完成之后修改/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

1.10、修改MySQL目录所有者

chown -R mysql:mysql /usr/local/mysql

1.11、添加MySQL服务

cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql

1.12、初始化数据库

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

注:初始化后会生成默认密码,请记录下来

1.13、创建数据库及表

/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.14、启动MySQL

service mysql start

1.15、进入MySQL命令行模式

/usr/local/mysql/bin/mysql -uroot -p

2、问题及解决方法

2.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;

3、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

  • 19
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

任我行2024

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值