docker搭建mysql双主双从

双主双从的作用就不说了
搭建环境:docker + linux + mysql5.7
架构方式
在这里插入图片描述
两台从机分布读取对应主机的数据,两台主机互相读取对方的数据

1.docker的mysql环境搭建

  1. mysql5.7的镜像这里不讲述如何创建
  2. 在/data/project/目录下创建4个mysql文件夹 例如mysql1/conf
  3. 其中1,2为master1和master2
  4. master1配置文件
[mysqld]

#主服务器唯一ID
server-id=1
#启用二进制日志
log-bin=mysql-bin

#从库的中继日志,主库日志写到中继日志,中继日志再重做到从库
# relay-log=myslql-relay-bin

#设置logbin格式。取值:STATEMENT (默认),ROW,MIXED
binlog_format=ROW

# 该从库是否写入二进制日志。如果需要成为多主则可启用。只读可以不需要
log-slave-updates=1

# 设置不要复制的数据库(可设置多个)
binlog-ignore-db=information_schema
binlog-ignore-db=mysql
binlog-ignore-db=performance_schema
binlog-ignore-db=sys

#设置需要复制的数据库(可选)。
# 如果要配置了此项,则 mysql 只复制下面指定的数据库。
# 如果不配置此项,则 mysql 默认复制所有的数据库(不包含 binlog-ignore-db 的数据库)
binlog-do-db=test
  1. master2配置文件
[mysqld]

#主服务器唯一ID
server-id=2
#启用二进制日志
log-bin=mysql-bin

#从库的中继日志,主库日志写到中继日志,中继日志再重做到从库
# relay-log=myslql-relay-bin

#设置logbin格式。取值:STATEMENT (默认),ROW,MIXED
binlog_format=ROW

# 该从库是否写入二进制日志。如果需要成为多主则可启用。只读可以不需要
log-slave-updates=1

# 设置不要复制的数据库(可设置多个)
binlog-ignore-db=information_schema
binlog-ignore-db=mysql
binlog-ignore-db=performance_schema
binlog-ignore-db=sys

#设置需要复制的数据库(可选)。
# 如果要配置了此项,则 mysql 只复制下面指定的数据库。
# 如果不配置此项,则 mysql 默认复制所有的数据库(不包含 binlog-ignore-db 的数据库)
binlog-do-db=test
  1. slave1配置文件
[mysqld]

#从服务器唯一ID
server-id=3
## 开启二进制日志功能,以备Slave作为其它Slave的Master时使用
log-bin=mysql-slave-bin   
#启用中继日志
relay-log=mysql-relay
  1. slave2配置文件
[mysqld]

#从服务器唯一ID
server-id=4
## 开启二进制日志功能,以备Slave作为其它Slave的Master时使用
log-bin=mysql-slave-bin   
#启用中继日志
relay-log=mysql-relay
  1. 创建docker容器
docker run -itd -p 4406:3306 -e MYSQL_ROOT_PASSWORD=123456 -v /data/project/mysql1/conf/my.cnf:/etc/mysql/my.cnf --name=mysql1 my-mysql:5.7
docker run -itd -p 4407:3306 -e MYSQL_ROOT_PASSWORD=123456 -v /data/project/mysql2/conf/my.cnf:/etc/mysql/my.cnf --name=mysql2 my-mysql:5.7
docker run -itd -p 4408:3306 -e MYSQL_ROOT_PASSWORD=123456 -v /data/project/mysql3/conf/my.cnf:/etc/mysql/my.cnf --name=mysql3 my-mysql:5.7
docker run -itd -p 4409:3306 -e MYSQL_ROOT_PASSWORD=123456 -v /data/project/mysql4/conf/my.cnf:/etc/mysql/my.cnf --name=mysql4 my-mysql:5.7

2.配置数据库

  1. 分别在两个主库中执行创建从库连接账号命令
# 在mysql1上执行,创建账号
GRANT replication SLAVE ON *.* TO 'slave' @'%' IDENTIFIED BY '123456';

# =========================

# 在mysql2上执行,创建账号
GRANT replication SLAVE ON *.* TO 'slave' @'%' IDENTIFIED BY '123456';
  1. 查看两个主库的master状态
# 在mysql1上执行
SHOW MASTER STATUS;
# 在得到结果后,不要再对此数据库进行修改操作

# =========================

# 在mysql2上执行
SHOW MASTER STATUS;

在这里插入图片描述

  1. 两个从库分别执行change master,连接到主库
# 在mysql3上执行,
change master to master_host='49.235.98.131',# 这里的ip就是mysql所在服务器对应的ip
master_user='slave', #就是在第一步配置的账号
master_port=4406, # mysql1的端口,
master_password='123456', #就是在第一步配置的密码
master_log_file='mysql-bin.000003', #就是在第二步获得结果中的file参数
master_log_pos=867; # 就是在第二步中获得结果中的Position参数

# 启动mysql3和mysql1两台服务的复制功能
start slave;

#查看连接状态 ,当 Slave_IO_Running 、Slave_SQL_Running 两个参数都是Yes,则说明主从配置成功!!!!
show slave status;

# =========================


# 在mysql4上执行
change master to master_host='49.235.98.131', # 这里的ip就是mysql所在服务器对应的ip
master_user='slave', #就是在第一步配置的账号
master_port=4407, # mysql2的端口,
master_password='123456', #就是在第一步配置的密码
master_log_file='mysql-bin.000003', #就是在第二步获得结果中的file参数
master_log_pos=591; # 就是在第二步中获得结果中的Position参数

# 启动mysql3和mysql1两台服务的复制功能
start slave;

#查看连接状态 ,当 Slave_IO_Running 、Slave_SQL_Running 两个参数都是Yes,则说明主从配置成功!!!!
show slave status;
  1. 两个主库再互相成为对方的从库
# 在mysql1上执行
CHANGE MASTER TO master_host = '49.235.98.131',
master_user = 'slave',
master_password = '123456',
master_port = 4407,
master_log_file = 'mysql-bin.000003',
master_log_pos = 591;

start slave;

show slave status;

# ============================

# 在mysql2上执行
CHANGE MASTER TO master_host = '49.235.98.131',
master_user = 'slave',
master_password = '123456',
master_port = 4406,
master_log_file = 'mysql-bin.000003',
master_log_pos = 867;

start slave;

show slave status;
  1. 验证
# 在mysql1上执行
CREATE TABLE `test` (
  `id` int(11) NOT NULL,
  `name` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

INSERT INTO test(`id`, `name`) VALUES (1, '2')

# 在其他3台上面执行,查看数据是否同步
show TABLES;

select * from test;
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值