mysql5.5以后,mysql的编译安装开始采用cmake的方式,使编译能够独立与源码之外工作,同时,编译版本的mysql兼容性非常好,而且易于卸载和移植到其他服务器上使用,本文讲述mysql5.7的编译安装过程;
?
?
准备工作
mysql安装包:mysql-5.7.19.tar.gz
编译依赖包: boost_1_59_0.tar.gz
安装环境:centos7服务器,磁盘大小20G左右,内存2G或以上
?
?
建立用户与组
groupadd -g 27 mysql
useradd -u 27 -g mysql -M -s /sbin/nologin mysql
?
?
创建目录
mkdir /usr/local/mysql?
mkdir /data/mysql
chown mysql:mysql -R /usr/local/mysql
chown mysql:mysql -R /data/mysql
?
?
解压软件包
mv mysql-5.7.19.tar.gz /usr/local/src
mv boost_1_59_0.tar.gz /usr/local/src
cd /usr/local/src
tar xf mysql-5.7.19.tar.gz
tar xf boost_1_59_0.tar.gz /usr/local/src
mkdir ./boost
mv boost_1_59_0 ./boost
?
?
配置编译环境
yum -y install gcc-c++ ncurses-devel cmake
?
?
开始编译
?
cd /usr/local/src/mysql-5.7.19
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/data/mysql -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DMYSQL_TCP_PORT=3306 -DMYSQL_UNIX_ADDR=/data/mysql/mysql.sock -DMYSQL_USER=mysql -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/local/src/boost
?
?
cmake参数解析
?
>-DCMAKE_INSTALL_PREFIX=/usr/local/mysql57#指定安装路径
>-DMYSQL_DATADIR=/data/mysql#指定数据库存放路径
>-DDEFAULT_CHARSET=utf8
>-DDEFAULT_COLLATION=utf8_general_ci ;#设置字符校验集
>-DMYSQL_TCP_PORT=3306
>-DMYSQL_UNIX_ADDR=/tmp/mysql.sock????#设置套接字生成路径
>-DMYSQL_USER=mysql
>-DWITH_MYISAM_STORAGE_ENGINE=1#存储引擎的支持
>-DWITH_INNOBASE_STORAGE_ENGINE=1
>-DWITH_ARCHIVE_STORAGE_ENGINE=1
>-DWITH_BLACKHOLE_STORAGE_ENGINE=1
>-DWITH_MEMORY_STORAGE_ENGINE=1
>-DDOWNLOAD_BOOST=1
>-DWITH_BOOST=/usr/local/src/boost#指定Boost扩展源码路径
?
?
开始安装
make && make install???????#需要时间很久
?
安装完成后,配置主配置文件,添加以下内容:
vim /etc/my.cnf
[client]
port=3306
socket=/data/mysql/mysql.sock
[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
skip-name-resolve
user=mysql
port=3306
basedir=/usr/local/mysql
datadir=/data/mysql
tmpdir=/tmp
socket=/data/mysql/mysql.sock
log-error=/data/mysql/mysql.log
pid-file=/data/mysql/mysqld.pid
?
进入数据库目录,进行数据库初始化
?
cd /data/mysql
/usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf --initialize --user=mysql
?
?
登录数据库,这个时候需要密码登录,但我们没有设置密码,可以通过数据库初始化时生成的随机密码登录(查看日志文件获取),但只能用一次,登录后必须立刻设置密码;
?
cd /data/mysql
cat cat mysql.log
?
找到" [email protected]: "字段后面的密文。
?
?
设置数据库密码
?
/usr/local/mysql/support-files/mysql.server start
/usr/local/mysql/bin/mysql -uroot -p"随机密码"
mysql> alter user ‘root‘@‘localhost‘ IDENTIFIED BY ‘123456‘;
mysql> grant all on *.* to ‘root‘@‘%‘ identified by ‘123456‘; #授权远程用户
mysql> flush privileges;#刷新密码权限表
mysql> exit
?
??重新登录测试,这时就可以使用刚才配置的密码登录了。
?
?
原文地址:http://blog.51cto.com/12443436/2287054