MySQL数据库实现主从复制,docker实现版

我这里是在同一台电脑上使用docker实现的主从复制,在物理机上整体思路是一致的

预备工作:安装好docker

使用docker运行MySQL

  1. 拉取MySQL镜像
docker pull mysql:5.7
  1. 运行mysql master容器
sudo docker run -p 33061:3306 --name mysql-master-v /mydata/mysql-master/conf:/etc/mysql/conf.d -v /mydata/mysql-master/logs:/logs -v /mydata/mysql-master/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -d mysql:5.7
  1. 运行mysql slave 容器
sudo docker run -p 33062:3306 --name mysql-slave  -v /mydata/mysql-slave/conf:/etc/mysql/conf.d -v /mydata/mysql-slave/logs:/logs -v /mydata/mysql-slave/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -d mysql:5.7

上边两个主要的区别就是端口号和对应的文件夹不一样

配置mysql master

  1. 在目录/mydata/mysql-master/conf下新增文件,文件名my.cnf,其中内容为
[mysqld]
log-bin=mysql-bin ##启用二进制日志
server_id=101  ## 设置server_id,同一局域网中需要唯一

这里的配置文件对应的在/etc/my.cnf,但是因为修改该文件不方便,所以这样去新增一个文件

  1. 然后重启mysql master
sudo docker restart mysql-master
  1. 创建用户并赋予REPUBLICATIONSLAVE权限。这里创建的用户名和密码都叫xiaoming

进入mysql

sudo docker exec -it mysql-master mysql -uroot -proot

创建用户和权限

GRANT REPLICATION SLAVE ON *.* to 'xiaoming'@'%' identified by 'xiaoming';
  1. 查看master状态
show master status;

在这里插入图片描述
此时就不要在主库做任何操作了,否则可能会变化,上图中的两个值后续会被用到。

配置mysql slave

  1. 在目录/mydata/mysql-slave/conf下新增文件,文件名my.cnf,其中内容为
[mysqld]
server_id=102  ## 设置server_id,同一局域网中需要唯一
  1. 重启mysql slave
sudo docker restart mysql-slave
  1. 配置mysql master的数据

登入mysql

sudo docker exec -it mysql-slave mysql -uroot -proot

设置master,其中的mysql_log_filemaster_log_pos就是配置master时的那两个值

change master to master_host='192.168.0.100',master_port=33061,master_user='xiaoming',master_password='xiaoming',master_log_file='mysql-bin.000001',master_log_pos=441;
  1. 开启同步
start slave;
  1. 查看状态
show slave status;

或使用下列命令竖排查看
show slave status\G;

此时Slave_IO_RunningSlave_SQL_Running应都为Yes,说明设置成功

在这里插入图片描述

此时对master库进行修改,slave库会同步修改

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值