MySQL5.7 的编译安装
发布于 2016-01-12 17:24

转载声明:著作权归作者所有,该内容欢迎转载,但转载时务必保留以下网址和作者信息。尊重原创,感谢有你!

作者:Chongyi 原文地址:https://www.insp.top/content/make-install-mysql-5-7

一直嫌弃 MySQL 的编译安装,原因很简单,依赖复杂、容易出错,总之就是麻烦。但这些天由于需要必须编译安装,被迫阅读相关文档,发现现在的 MySQL 安装变得十分简单和容易。

直接开始吧。

一切从必要依赖开始。

yum install -y gcc gcc-c++ ncurses-devel perl

本文中系统为 CentOS 7,不同系统的软件包管理器可能用法不同,但需求类似,请准备好 gcc gcc++ ncurses 及 perl 相关编译器或依赖库即可。

必要的文件准备:

首先需要安装 cmake,因此解压刚刚下载的 cmake 3.4.1 编译安装,步骤如下:

tar -xzvf cmake-3.4.1.tar.gz cd cmake-3.4.1 ./bootstrap make && make install

安装完 cmake,就开始着手 MySQL 编译安装的步骤。首先为添加 MySQL 对应的系统账户,用于保证其本地文件权限分配:

groupadd mysql useradd -r -g mysql mysql

创建数据库目录:

mkdir -p /var/mysql/data chown mysql:mysql /var/mysql/data

开始准备编译安装,解压 mysql-boost-5.7.10.tar.gz 并进入其解压后的 mysql-5.7.10 目录,在该目录下执行:

cmake \ -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \ -DDEFAULT_CHARSET=utf8mb4 \ -DDEFAULT_COLLATION=utf8mb4_general_ci \ -DWITH_INNOBASE_STORAGE_ENGINE=1 \ -DWITH_ARCHIVE_STORAGE_ENGINE=1 \ -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \ -DMYSQL_DATADIR=/var/mysql/data \ -DMYSQL_TCP_PORT=3306 \ -DWITH_BOOST=boost

除了上述参数,编译安装的参数还有很多很多,若需要了解每一个参数的具体含义或者参数的默认值,可以到 MySQL 官网的文档里查阅,在此给出这一版本的查阅地址: http://dev.mysql.com/doc/refman/5.7/en/source-configuration-options.html

执行完 cmake 的配置过程,就需要开始准备最为 漫长的 的编译过程,根据不同机器的配置,时间大约在 2 小时左右(低配情况下 4 小时以上也是可能的)。执行编译和安装操作已经很熟悉了: make && make install

好的,进行完以上步骤,首先需要改变 mysql 安装目录的所有者,比如我们安装的目录是 /usr/local/mysql,使用命令

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

修改目录所有者。此时,复制一份默认配置文件

cp /usr/local/mysql/support-files/my-default.cnf /etc/my.cnf

如果提示已存在文件是否覆盖时,覆盖即可。

然后执行数据库的初始化操作,

/usr/local/mysql/bin/mysqld --initialize --user=mysql

这时候会初始化数据库并创建一个数据库 root 账号,但是要注意,和以前不一样的是,这个账号是有默认密码的,初始化的时候屏幕上会输出初始化的密码,如果错过了,可以通过查看 /root/.mysql_secret 即可看到默认的密码。

执行 cp /usr/local/mysql/support-files/mysql.server /etc/init.d,将 mysql 的服务启动脚本复制过去,然后执行 service mysql.server start 启动 mysql。

最后 /usr/local/mysql/bin/mysql -u root -p,输入密码回车,通过

set password=password('你的密码');

来修改默认密码

至此,基本的安装流程完毕!你可以根据需要,将 mysql 加入开启启动,也可以将 /usr/local/mysql/bin 下的文件加入 PATH 环境变量,更多使用方式可以参考官方文档,写的十分细致。

灵感 INSPIRER