centos7下mysql5.7编译安装

  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

 
找到" root@localhost: "字段后面的密文。

 
 
设置数据库密码
 

/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

 
  重新登录测试,这时就可以使用刚才配置的密码登录了。
 
 

猜你喜欢

转载自blog.51cto.com/12443436/2287054