首页 > 数据库技术 > 详细

CentOS7.5源码编译安装mysql5.7.29

时间:2020-03-07 10:56:28      阅读:49      评论:0      收藏:0      [点我收藏+]

 #查看系统版本

[root@ctos3 ~]# cat /etc/redhat-release 
CentOS Linux release 7.5.1804 (Core) 

 

#下载源码包,需要注意的是mysql5.7 编译安装需要boost 库,可以在官网下载含boost的源码包

技术分享图片

 

#提示,下载的时候如果不想进行登录或注册,就点不用,开始下载

技术分享图片

 

#开始源码编译安装

#1.安装相关依赖包

yum install -y gcc gcc-c++ cmake ncurses ncurses-devel bison wget openssl-devel.x86_64

 

#2.创建用户和组

groupadd  mysql
useradd mysql -s /sbin/nologin -M -g mysql

 

#3.下载mysql和解压,也可以下载好使用rz(包名lrzsz)上传

mkdir /home/demo/tools/
cd /home/demo/tools/
wget https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-boost-5.7.29.tar.gz
tar xf mysql-boost-5.7.29.tar.gz

 

#4.配置相关参数

[root@ctos3 tools]# cd mysql-5.7.29/
[root@ctos3 mysql-5.7.29]# pwd
/home/demo/tools/mysql-5.7.29
[root@ctos3 mysql-5.7.29]# cmake -DCMAKE_INSTALL_PREFIX=/application/mysql  -DMYSQL_DATADIR=/application/mysql/data -DMYSQL_UNIX_ADDR=/application/mysql/tmp/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_BOOST=boost

#参数介绍

DCMAKE_INSTALL_PREFIX  #指定MySQL程序的安装目录
DMYSQL_DATADIR         #数据文件目录
DMYSQL_UNIX_ADDR       #socket文件路径
DDEFAULT_CHARSET       #指定服务器默认字符集,默认latin1
DDEFAULT_COLLATION     #指定服务器默认的校对规则,默认latin1_general_ci

 

#5.编译安装

[root@ctos3 mysql-5.7.29]# make -j 2 && make install

#-j参数作用:编译时会占用大量的系统资源,可以通过-j参数指定多个编译命令进行并行编译来提高速度,使用以下命令查看系统CPU核数

[root@ctos3 ~]# cat /proc/cpuinfo | grep processor |wc -l
2

 

#6.创建数据目录和修改权限

[root@ctos3 mysql-5.7.29]# mkdir /application/mysql/data  #存放数据目录

[root@ctos3 mysql-5.7.29]# mkdir /application/mysql/tmp   #存放sock目录

[root@ctos3 mysql-5.7.29]# chown -R mysql.mysql /application/mysql/

 

#7.配置/etc/my.cnf文件

#注意:5.7版本没有模板文件/application/mysql/support-files/my-default.cnf,可根据需要自行添加

[root@ctos3 ~]# cat /etc/my.cnf
[mysqld]
port = 3306
socket = /application/mysql/tmp/mysql.sock
user = mysql
basedir = /application/mysql
datadir = /application/mysql/data
pid-file = /application/mysql/data/mysql.pid
sql_mode=ONLY_FULL_GROUP_BY
log_error = /application/mysql/mysql-error.log
!includedir /etc/my.cnf.d

[client]
port = 3306
socket = /application/mysql/tmp/mysql.sock

 

#8.初始化数据库

[root@ctos3 support-files]# /application/mysql/bin/mysqld --initialize-insecure --user=mysql --basedir=/application/mysql --datadir=/application/mysql/data

 

 #9.生成服务启动脚本

#设置环境变量
[root@ctos3 support-files]# echo export PATH=/application/mysql/bin:$PATH >> /etc/profile
[root@ctos3 support-files]# source /etc/profile
[root@ctos3 support-files]# tail -1 /etc/profile
export PATH=/application/mysql/bin:$PATH

#生成启动脚本
[root@ctos3 ~]# cd /application/mysql/support-files/
[root@ctos3 support-files]# ls
magic  mysqld_multi.server  mysql-log-rotate  mysql.server
[root@ctos3 support-files]# cp mysql.server /etc/init.d/mysqld

#启动服务和设置开机自启
[root@ctos3 support-files]# /etc/init.d/mysqld start
Starting MySQL. SUCCESS! 
[root@ctos3 support-files]# chkconfig --add mysqld [root@ctos3 support
-files]# chkconfig mysqld on

 

#10.登录MySQL(没有密码登录)

[root@ctos3 ~]# mysql -uroot -p
Enter password: 

 

#11.查看版本

mysql> select version();
+-----------+
| version() |
+-----------+
| 5.7.29    |
+-----------+
1 row in set (0.00 sec)

 

#12.设置密码

mysql> update mysql.user set authentication_string=password(guoke123) where user=root;
Query OK, 1 row affected, 1 warning (0.01 sec)
Rows matched: 1  Changed: 1  Warnings: 1

mysql> flush privileges;
Query OK, 0 rows affected (0.01 sec)

 

 #将配置放进脚本一键执行

yum install -y gcc gcc-c++ cmake ncurses ncurses-devel bison wget openssl-devel.x86_64
groupadd  mysql
useradd mysql -s /sbin/nologin -M -g mysql

mkdir /home/demo/tools/
cd /home/demo/tools/
wget https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-boost-5.7.29.tar.gz
tar xf mysql-boost-5.7.29.tar.gz

cd mysql-5.7.29/
cmake -DCMAKE_INSTALL_PREFIX=/application/mysql  -DMYSQL_DATADIR=/application/mysql/data -DMYSQL_UNIX_ADDR=/application/mysql/tmp/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_BOOST=boost
make -j 2 && make install

mkdir /application/mysql/data/
mkdir /application/mysql/tmp
chown  -R mysql.mysql /application/mysql/

cat >>/etc/my.cnf<<EOF
[mysqld]
port = 3306
socket = /application/mysql/tmp/mysql.sock
user = mysql
basedir = /application/mysql
datadir = /application/mysql/data
pid-file = /application/mysql/data/mysql.pid
sql_mode=ONLY_FULL_GROUP_BY
log_error = /application/mysql/mysql-error.log
[client]
port = 3306
socket = /application/mysql/tmp/mysql.sock
EOF
/application/mysql/bin/mysqld --initialize-insecure --user=mysql --basedir=/application/mysql --datadir=/application/mysql/data

echo export PATH=/application/mysql/bin:$PATH >> /etc/profile
source /etc/profile
cd /application/mysql/support-files/
cp mysql.server  /etc/init.d/mysqld
/etc/init.d/mysqld start
chkconfig mysqld on

 

 

CentOS7.5源码编译安装mysql5.7.29

原文:https://www.cnblogs.com/guoke-boy/p/12431850.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!