关键词:CentOS6.4 MySql5.7.17 源代码安装
本文分成两部分来讲MySQL源码安装。第一部分详细介绍安装步骤。第二部分介绍安装过程中遇到的问题如何解决。
第一部分:操作步骤
- 确认操作系统类型,这个关系到后续安装哪个版本的MySQL的。
[root@localhost ~]# cat /etc/issue
CentOS release 6.4 (Final)
Kernel \r on an \m - 确认操作系统位数
[root@localhost ~]# getconf LONG_BIT
64 -
在MySQL官网下载源码。
通过源码编译的方式来安装。
MySQL官网选择合适版本
这两个都可以。区别就是第一个,需要自己在安装MySQL过程中下载Boost文件。我选择的是第一个。
- 预先安装依赖软件
yum install -y gcc-c++ make cmake bison bison-devel ncurses-devel libaio-devel perl perl-Data-Dumper - 创建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 - 安装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 - 创建MySQL安装目录和数据目录
mkdir /usr/local/mysql
mkdir /usr/local/mysql/data - 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分钟, - 安装完成之后修改/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 - 修改MySQL目录所有者
chown -R mysql:mysql /usr/local/mysql - 添加MySQL服务
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql - 初始化数据库
/usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
注:初始化后会生成默认密码,请记录下来 - 创建数据库及表
/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
- 启动MySQL
service mysql start - 开启MySQL
/usr/local/mysql/bin/mysql -uroot -p
第二部分:问题及解决方法
-
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 服务,使用新密码登录。 -
mysql连接成功后,输入sql命令,报错You must SET PASSWORD before executing this statement
alter user 'root'@'localhost' identified by '自定义密码';
flush privileges;
- 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
网友评论