Docker搭建MySQL8主从复制 (全网最详细版)

使用Docker搭建主从
使用Docker拉取MySQL镜像,使用8.0.19版本

1.下载8.0.19版本:

docker pull mysql:8.0.19

2.下载完成后,可以使用如下命令查看mysql镜像:

docker images

3.使用下载好的镜像搭建MySQL主从

Master:

docker run -p 3306:3306 --name mysql-master -e MYSQL_ROOT_PASSWORD=12345678 -d mysql:8.0.19

Slave:

docker run -p 3307:3306 --name mysql-slave -e MYSQL_ROOT_PASSWORD=12345678 -d mysql:8.0.19

Master对外映射的端口号是3306,Slave对外映射的端口号是3306,大家可以自己随意设置。因为docker容器是相互隔离的,每个容器有其独立的IP地址,所以不同容器使用相同的端口并不会冲突。如果是在生产环境,肯定是在不同的机器上安装MySQL,相对来说会简单一些。
在这里插入图片描述

在这里插入图片描述

4.容器启动完成后,可以通过MySQL连接工具进行连接测试,看是否能成功

在这里插入图片描述
在这里插入图片描述

5.配置Master

使用如下命令进入到Master容器内部,使用容器ID或者名称均可:

docker exec -it 8b71301f25ed /bin/bash		 //8b71301f25ed为容器ID
docker exec -it mysql-master /bin/bash		 //mysql-master为容器名称

切换到 /etc/mysql 目录下
在这里插入图片描述

使用vim命令编辑my.cnf文件,会出现bash: vim: command not found,因此我们需要在docker内部安装vim工具
在这里插入图片描述

docker内部安装vim
很简单,依次输入如下命令即可安装,时间和网速有关,耐心等待。

apt-get update
apt-get install vim

安装成功后,编辑my.cnf文件

[mysqld]
##同一局域网内注意要唯一
server-id=100  
##开启二进制日志功能,可以随便取(关键)
log-bin=master-bin
binlog-format=ROW     // 二级制日志格式,有三种 row,statement,mixed
binlog-do-db=数据库名  //同步的数据库名称,如果不配置,表示同步所有的库

配置完成后,退出docker容器,重启mysql服务使其修改的配置文件生效,使用如下命令使mysql进行重启

docker restart mysql-master
1

6.配置Slave

类似于Master,使用docker命令docker exec -it mysql-slave /bin/bash 进入到slave容器中,进入到etc/mysql路径,使用vim命令编辑my.cnf文件:

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

配置完成后,退出docker容器,重启mysql服务使其修改的配置文件生效,使用如下命令使mysql进行重启

docker restart mysql-slave

7.开启Master-Slave主从复制

7.1 进入Master库mysql客户端:输入show master status查看Master状态:
在这里插入图片描述

7.2 记住File和Position,后面需要用到。此时一定不要操作Master库,否则将会引起Master状态的变化,File和Position字段也将会进行变化。
master_host :Master库的地址,指的是容器的独立ip,可以通过
docker inspect --format='{{.NetworkSettings.IPAddress}}' 容器名称 | 容器id查询容器的IP进行查询:

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

在这里插入图片描述

7.3 进入到Slave库myslq客户端,执行如下命令:

change master to master_host='172.17.0.2', master_user='root', master_password='12345678', master_port=3306, master_log_file='master-bin.000001', master_log_pos=3552, master_connect_retry=30;

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

启动slave

start slave

查询slave

show slave status \G;

在这里插入图片描述
使用start slave开启主从复制过程后,如果SlaveIORunning一直是Connecting,则说明主从复制一直处于连接状态,这种情况一般是下面几种原因造成的,我们可以根据 Last_IO_Error提示予以排除。
在这里插入图片描述

1、网络不通:检查ip,端口
2、密码不对:检查是否创建用于同步的用户和用户密码是否正确
3、pos不对:检查Master的 Position

正常启动后如下必须二个都位YES
在这里插入图片描述

Slave_IO_RunningSlave_SQL_Running 都是Yes,说明主从复制已经开启。此时可以测试数据同步是否成功。

8.主从复制测试

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

补充: show slave status\G 的完成配置信息
如何停止从服务复制功能
使用stop slave;命令

如何重新配置主从
使用这两个命令 stop slave; reset master;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值