docker搭建mysql读写分离、一主二从、并挂载数据、配置文件

主库

创建文件夹用户挂载

mkdir -p /data/docker/mysql-cluster/{master,slave1,slave2}

新建配置文件

cd /data/docker/mysql-cluster/master
mkdir conf
cd conf
echo "" > my.cnf

分别复制一份到从库

cp -r /data/docker/mysql-cluster/master/conf /data/docker/mysql-cluster/slave1/
cp -r /data/docker/mysql-cluster/master/conf /data/docker/mysql-cluster/slave2/

启动主库

docker run --name mysql-master -d -p 13306:3306 \
-v /data/docker/mysql-cluster/master/data:/var/lib/mysql \
-v /data/docker/mysql-cluster/master/conf:/etc/mysql \
-v /data/docker/mysql-cluster/master/logs:/var/log/mysql \
-v /etc/localtime:/etc/localtime \
-e MYSQL_ROOT_PASSWORD=123456 \
mysql:5.7.36

从库

运行从库1

docker run --name mysql-slave1 -d -p 13307:3306 \
-v /data/docker/mysql-cluster/slave1/data:/var/lib/mysql \
-v /data/docker/mysql-cluster/slave1/conf:/etc/mysql \
-v /data/docker/mysql-cluster/slave1/logs:/var/log/mysql \
-v /etc/localtime:/etc/localtime \
-e MYSQL_ROOT_PASSWORD=123456 \
mysql:5.7.36

运行从库2

docker run --name mysql-slave2 -d -p 13308:3306 \
-v /data/docker/mysql-cluster/slave2/data:/var/lib/mysql \
-v /data/docker/mysql-cluster/slave2/conf:/etc/mysql \
-v /data/docker/mysql-cluster/slave2/logs:/var/log/mysql \
-v /etc/localtime:/etc/localtime \
-e MYSQL_ROOT_PASSWORD=123456 \
mysql:5.7.36

修改主库挂载配置文件my.cnf,并保存退出

[mysqld]
# 同一局域网内注意要唯一
server-id=13306
# 开启二进制日志功能,可以随便取(关键)
log-bin=master-bin
binlog-format=ROW     // 二级制日志格式,有三种 row,statement,mixed
# binlog-do-db=数据库名  //同步的数据库名称,如果不配置,表示同步所有的库
# 配置数据库最大连接数量
max_connections=2000
# bin日志文件过期时间,默认0不过期,配置此项,防止文件过大导致磁盘过大
expire_logs_days=7

重启服务使配置生效

docker restart mysql-master
  • 创建数据库同步账号
# 进入容器
docker exec -it mysql-master bash
# 登录mysql
mysql -uroot -p123456
# 创建slave账号
CREATE USER 'slave'@'%' IDENTIFIED BY '123456';
# 给slave授权
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';

配置从库(1)my.cnf

[mysqld]
# 设置server_id,注意要唯一
server-id=13307 
# 开启二进制日志功能,以备Slave作为其它Slave的Master时使用
log-bin=slave1-bin   
## relay_log配置中继日志
relay_log=mysql-relay-bin  
read_only=1  ## 设置为只读,该项如果不设置,表示slave可读可写
# 配置数据库最大连接数量
max_connections=2000
# bin日志文件过期时间,默认0不过期,配置此项,防止文件过大导致磁盘过大
expire_logs_days=7

配置从库(2)my.cnf

[mysqld]
# 设置server_id,注意要唯一
server-id=13308
# 开启二进制日志功能,以备Slave作为其它Slave的Master时使用
log-bin=slave2-bin   
## relay_log配置中继日志
relay_log=mysql-relay-bin  
read_only=1  ## 设置为只读,该项如果不设置,表示slave可读可写

查看主库IP地址

docker inspect --format='{{.NetworkSettings.IPAddress}}' mysql-master

在这里插入图片描述

再次进入主库,并登录root账号

docker exec -it mysql-master bash
# 登录
mysql -uroot -p123456

执行指令show master status;

在这里插入图片描述
退出主库

分别进入从库并登录root账号

# 进入容器
docker exec -it mysql-slave1 bash
# 登录root账号
mysql -uroot -p123456

执行指令1

change master to master_host='172.17.0.9', master_user='slave', master_password='123456', master_port=3306, master_log_file='master-bin.000001', master_log_pos=154, master_connect_retry=30;

指令说明:

master_host :Master库的地址,指的是容器的独立ip,可以通过docker inspect --format='{{.NetworkSettings.IPAddress}}' mysql-master查看
master_port:Master的端口号,指的是容器的端口号
master_user:用于数据同步的用户
master_password:用于同步的用户的密码
master_log_file:指定 Slave 从哪个日志文件开始复制数据,即上文中提到的 File 字段的值
master_log_pos:从哪个 Position 开始读,即上文中提到的 Position 字段的值
master_connect_retry:如果连接失败,重试的时间间隔,单位是秒,默认是60秒

执行指令2

# 开始从库
start slave;
# 格式化输出slave状态
show slave status \G;
# Slave_IO_Running 和 Slave_SQL_Running是查看主从是否运行的关键字段,默认为NO,表示没有进行主从复制。为YES表示开启成功

从库2同步设置

同样的操作在slave2上执行一次即可

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是使用docker搭建mysql双主双从加读写分离的详细步骤: 1. 安装dockerdocker-compose 2. 创建docker-compose文件 在本地创建一个目录,例如`/mysql_cluster`,在该目录下创建一个`docker-compose.yml`文件,并添加以下内容: ``` version: '3' services: mysql-master1: image: mysql:5.7 container_name: mysql-master1 environment: MYSQL_ROOT_PASSWORD: root MYSQL_DATABASE: testdb volumes: - ./master1/conf:/etc/mysql/conf.d - ./master1/data:/var/lib/mysql ports: - "3301:3306" mysql-master2: image: mysql:5.7 container_name: mysql-master2 environment: MYSQL_ROOT_PASSWORD: root MYSQL_DATABASE: testdb volumes: - ./master2/conf:/etc/mysql/conf.d - ./master2/data:/var/lib/mysql ports: - "3302:3306" mysql-slave1: image: mysql:5.7 container_name: mysql-slave1 environment: MYSQL_ROOT_PASSWORD: root volumes: - ./slave1/conf:/etc/mysql/conf.d - ./slave1/data:/var/lib/mysql ports: - "3303:3306" depends_on: - mysql-master1 - mysql-master2 mysql-slave2: image: mysql:5.7 container_name: mysql-slave2 environment: MYSQL_ROOT_PASSWORD: root volumes: - ./slave2/conf:/etc/mysql/conf.d - ./slave2/data:/var/lib/mysql ports: - "3304:3306" depends_on: - mysql-master1 - mysql-master2 ``` 3. 创建配置文件 在`/mysql_cluster`目录下创建四个文件夹`master1`、`master2`、`slave1`、`slave2`,分别用于存放四个mysql实例的配置文件数据。 在`master1`文件夹下创建一个`my.cnf`文件,并添加以下内容: ``` [mysqld] server-id=1 log-bin=mysql-bin binlog-do-db=testdb replicate-do-db=testdb ``` 在`master2`文件夹下同样创建一个`my.cnf`文件,并修改`server-id`为`2`。 在`slave1`文件夹下创建一个`my.cnf`文件,并添加以下内容: ``` [mysqld] server-id=3 log-bin=mysql-bin binlog-do-db=testdb replicate-do-db=testdb relay-log=slave-relay-bin log-slave-updates=1 read-only=1 ``` 在`slave2`文件夹下同样创建一个`my.cnf`文件,并修改`server-id`为`4`。 4. 启动容器 在`/mysql_cluster`目录下运行以下命令启动容器: ``` docker-compose up -d ``` 5. 配置主从复制 进入`mysql-slave1`容器,执行以下命令: ``` CHANGE MASTER TO MASTER_HOST='mysql-master1', MASTER_PORT=3306, MASTER_USER='root', MASTER_PASSWORD='root', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=154; ``` 进入`mysql-slave2`容器,执行以下命令: ``` CHANGE MASTER TO MASTER_HOST='mysql-master2', MASTER_PORT=3306, MASTER_USER='root', MASTER_PASSWORD='root', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=154; ``` 6. 配置读写分离 在`mysql-master1`和`mysql-master2`容器中执行以下命令: ``` GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION; FLUSH PRIVILEGES; ``` 7. 测试 现在我们已经成功搭建mysql双主双从加读写分离的集群。我们可以使用以下命令测试: 在`mysql-master1`或`mysql-master2`中创建一个数据库: ``` create database testdb; ``` 在`mysql-slave1`和`mysql-slave2`中查看是否同步成功: ``` show databases; ``` 在`mysql-master1`或`mysql-master2`中创建一个表: ``` use testdb; create table t1(id int, name varchar(20)); ``` 在`mysql-slave1`和`mysql-slave2`中查看是否同步成功: ``` use testdb; show tables; ``` 在应用程序中测试读写分离是否成功: ``` jdbc:mysql://localhost:3301,localhost:3302/testdb?useUnicode=true&characterEncoding=utf-8&useSSL=false&autoReconnect=true ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值