centos 7 部署两个 mysql 8.0.31(非常详细)

本文在一台 centos 7 机器上同时部署了两个 mysql 实例,其端口号分别为:3306、3307!

废话不多说,开干!!!

一、前期准备工作

1、mysql-boost-8.0.31.tar.gz 源码下载

下载地址:https://dev.mysql.com

2、配置阿里云镜像源

cpp 复制代码
cd /etc/yum.repos.d 
vi scl.repo 
 
# scl.repo文件内容如下:
 
[scl] 
name=CentOS-7 - SCLo sclo 
baseurl=http://mirrors.aliyun.com/centos/7/sclo/x86_64/rh/ 
gpgcheck=0 
enabled=1 

3、安装 gcc、cmake、Boost C++库、ncurses库、OpenSSL库

注意:需要cmake3,gcc-5.3以上;

安装命令如下:

cpp 复制代码
yum install devtoolset-7-gcc devtoolset-7-gcc-c++ 
source /opt/rh/devtoolset-7/enable 
gcc -v   //查看gcc版本
 
yum install epel* 
yum clean all 
yum makecache 
yum install cmake3 ncurses ncurses-devel bison openssl*

二、部署准备

1、将 mysql-boost-8.0.31.tar.gz,传输到 /usr/local/ 目录下,并进行解压

cpp 复制代码
tar zxvf mysql-boost-8.0.31.tar.gz

2、在 /usr/local/ 目录下创建多个 mysql 安装目录

cpp 复制代码
# 端口号为 3306 的 mysql 安装目录
mkdir mysql3306

# 端口号为 3307 的 mysql 安装目录
mkdir mysql3307

3、 进入到 cd mysql-8.0.31 目录下,创建 3306、3307 的编译目录

cpp 复制代码
cd mysql-8.0.31

mkdir bld3306

mkdir bld3307

三、部署第一个 mysql(端口号为3306)

1、编译第一个 MySQL 实例

cpp 复制代码
cd bld3306

# -DMYSQL_TCP_PORT=3306 为指定端口号
# /usr/local/mysql3306 为 mysql3306 安装目录
cmake3 -DMYSQL_TCP_PORT=3306 -DDEFAULT_CHARSET=utf8mb4 -DDEFAULT_COLLATION=utf8mb4_general_ci -DCMAKE_INSTALL_PREFIX=/usr/local/mysql3306 -DWITH_BOOST=../boost ..

make -j4

2、安装第一个 MySQL 实例

cpp 复制代码
make install

3、配置第一个 MySQL 配置文件

cpp 复制代码
vim /etc/my3306.cnf

# 文件内容如下


[client] 
socket=/usr/local/mysql3306/data/mysql.sock 
 
[mysqld] 
datadir=/usr/local/mysql3306/data 
socket=/usr/local/mysql3306/data/mysql.sock 
 
#Disabling symbolic-links is recommended to prevent assorted security risks 
symbolic-links=0 
log-error=/usr/local/mysql3306/data/mysqld.log 
pid-file=/usr/local/mysql3306/data/mysqld.pid 
server-id=1
port=3306

#是否只读,1代表只读,0代表读写
read-only=0

#忽略的数据,指不需要同步的数据库
#binlog-ignore-db=mysql
#指定同步的数据库
#binlog-do-db=db01

4、初始化第一个 MySQL 实例

cpp 复制代码
# 进入安装目录
cd /usr/local/mysql3306

# 初始化
bin/mysqld --defaults-file=/etc/my3306.cnf --initialize --user=mysql3306 --port=3306

5、启动第一个 MySQL 实例

cpp 复制代码
bin/mysqld_safe --user=mysql3306 --port=3306 &

6、设置第一个 MySQL 实例的 root 密码

cpp 复制代码
# 执行下述命令并使用初始密码进入 mysql
bin/mysql -u root -p -P 3306


ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';

7、完成第一个 MySQL 实例部署

四、部署第二个 mysql (端口号为3307)

1、编译第二个 MySQL 实例

cpp 复制代码
cd bld3307

# -DMYSQL_TCP_PORT=3307 为指定端口号
# /usr/local/mysql3307 为 mysql3307 安装目录
cmake3 -DMYSQL_TCP_PORT=3307 -DDEFAULT_CHARSET=utf8mb4 -DDEFAULT_COLLATION=utf8mb4_general_ci -DCMAKE_INSTALL_PREFIX=/usr/local/mysql3307 -DWITH_BOOST=../boost ..

make -j4

2、安装第二个 MySQL 实例

cpp 复制代码
make install

3、配置第二个 MySQL 配置文件

cpp 复制代码
vim /etc/my3307.cnf

# 文件内容如下


[client] 
socket=/usr/local/mysql3307/data/mysql.sock 
 
[mysqld] 
datadir=/usr/local/mysql3307/data 
socket=/usr/local/mysql3307/data/mysql.sock 
 
#Disabling symbolic-links is recommended to prevent assorted security risks 
symbolic-links=0 
log-error=/usr/local/mysql3307/data/mysqld.log 
pid-file=/usr/local/mysql3307/data/mysqld.pid 
server-id=2
port=3307

#是否只读,1代表只读,0代表读写
read-only=0

#忽略的数据,指不需要同步的数据库
#binlog-ignore-db=mysql
#指定同步的数据库
#binlog-do-db=db01

4、初始化第二个 MySQL 实例

cpp 复制代码
# 进入安装目录
cd /usr/local/mysql3307

# 初始化
bin/mysqld --defaults-file=/etc/my3307.cnf --initialize --user=mysql3307 --port=3307

5、启动第二个 MySQL 实例

cpp 复制代码
bin/mysqld_safe --user=mysql3307 --port=3307 &

6、设置第一个 MySQL 实例的 root 密码

cpp 复制代码
# 执行下述命令并使用初始密码进入 mysql
bin/mysql -u root -p -P 3307


ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';

7、完成第二个 MySQL 实例部署

相关推荐
程序员小崔日记4 小时前
一篇文章彻底搞懂 MySQL 和 Redis:原理、区别、项目用法全解析(建议收藏)
redis·mysql·项目实战
武子康5 小时前
大数据-241 离线数仓 - 实战:电商核心交易数据模型与 MySQL 源表设计(订单/商品/品类/店铺/支付)
大数据·后端·mysql
用户8307196840821 天前
MySQL 查询优化 30 条封神技巧:用好索引,少耗资源,查询快到飞起
mysql
Nyarlathotep01131 天前
事务隔离级别
sql·mysql
Nyarlathotep01131 天前
SQL的事务控制
sql·mysql
用户86178277365181 天前
MySQL 8.0从库宕机排查实录:中继日志膨胀引发的连锁故障复盘
mysql
随风飘的云2 天前
mysql的innodb引擎对可重复读做了那些优化,可以避免幻读
mysql
xy123064 天前
OpenStack Train 部署实战(三)控制节点--keystone服务
centos·openstack
于眠牧北5 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
Turnip12027 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql