kution 发表于 2019-2-15 17:29:22

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/nologinmysql

  
 
创建目录

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

  
 
解压软件包

  mvmysql-5.7.19.tar.gz   /usr/local/src
mvboost_1_59_0.tar.gz/usr/local/src
cd /usr/local/src
tar xfmysql-5.7.19.tar.gz
tar xfboost_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



port=3306
socket=/data/mysql/mysql.sock

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
catcat 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]
查看完整版本: centos7下mysql5.7编译安装