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

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

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值