多容器如何实现mysql同步_docker学习系列12 轻松实现 mysql 主从同步

docker的一大好处是在本地可以很方便快速的搭建负载均衡,主从同步等需要多主机的环境。

可以说是极大方便了运维成本和难度。

本节在本地搭建mysql的一主一从的集群环境。

关于主从同步的流程图,放张网上找的流程图AAffA0nNPuCLAAAAAElFTkSuQmCC

image.png

以mysql5.7为例创建 mysql-master-slave 目录,比如完整路径是

D:/docker/mysql-master-slave

目录结构如下:

-- master

-- data

mysqld.cnf

-- slave

-- data

mysqld.cnf

其中master目录底下的 mysqld.cnf 配置文件内容为[mysqld]

pid-file    = /var/run/mysqld/mysqld.pid

socket      = /var/run/mysqld/mysqld.sock

datadir     = /var/lib/mysql#log-error  = /var/log/mysql/error.log# By default we only accept connections from localhost#bind-address   = 127.0.0.1# Disabling symbolic-links is recommended to prevent assorted security riskssymbolic-links=0# 以下是新增内容# 标识不同的数据库服务器,而且唯一server-id=1# 启用二进制日志log-bin=mysql-bin

log-slave-updates=1innodb_flush_log_at_trx_commit = 2innodb_flush_method = O_DIRECT

skip-host-cache

skip-name-resolve

slave 目录底下的 mysqld.cnf 内容为[mysqld]

pid-file            = /var/run/mysqld/mysqld.pid

socket      = /var/run/mysqld/mysqld.sock

datadir     = /var/lib/mysql#log-error  = /var/log/mysql/error.log# By default we only accept connections from localhost#bind-address   = 127.0.0.1# Disabling symbolic-links is recommended to prevent assorted security riskssymbolic-links=0# 以下是新增内容server-id=2log-bin=mysql-binlog-slave-updates=1# 多主的话需要注意这个配置,防止自增序列冲突。auto_increment_increment=2

auto_increment_offset=2read-only=1

slave-skip-errors = 1062

skip-host-cache

skip-name-resolve基于官方mysql镜像,运行两个容器并指定一些参数

启动 名称为mysql_master的容器作为master数据库

docker run --name mysql_master -d -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 -v D:/docker/mysql-master-slave/master/data:/var/lib/mysql -v D:/docker/mysql-master-slave/master/mysqld.cnf:/etc/mysql/mysql.conf.d/mysqld.cnf mysql:5.7

docker run —name mysql_slave -d -p 3308:3306 -e MYSQL_ROOT_PASSWORD=123456 -v D:/docker/mysql-master-slave/slave/data:/var/lib/mysql -v D:/docker/mysql-master-slave/slave/mysqld.cnf:/etc/mysql/mysql.conf.d/mysqld.cnf mysql:5.7

这个时候宿主机的 Navicat 应该可以连上容器里的两个数据库了。配置主从同步,新开终端进入容器

docker exec -it mysql_master bash

mysql -u root -p

创建一个同步数据权限的用户

GRANT REPLICATION SLAVE ON *.* to 'backup'@'%' identified by '123456';

查看状态,记住File、Position的值,在 Slave 中将用到

show master status;AAffA0nNPuCLAAAAAElFTkSuQmCC

image.png

进入slave容器

docker exec -it mysql_slave bash

mysql -u root -p

设置主库链接

change master to master_host='172.17.0.2',master_user='backup',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=0,master_port=3306;

启动从库同步

start slave

查看状态,如果 Slave_SQL_Running_State 是 Slave has read all relay log; waiting for more updates 表示正常运行。

show slave status \GAAffA0nNPuCLAAAAAElFTkSuQmCC

image.png测试同步,在master上新建一个数据库

docker exec mysql_master mysql -uroot -p123456 -e "CREATE DATABASE test"

docker exec mysql_slave mysql -uroot -p123456 -e "SHOW DATABASES"

总结:mysqld.cnf 文件的由来?

答:就是从容器内的 /etc/mysql/mysql.conf.d/mysqld.cnf 拷贝出来的

主从同步的简单原理?

答:

MySQL的主从复制是一个异步的复制过程,数据库从一个Master复制到Slave数据库,在Master与Slave之间实现整个主从复制的过程是由三个线程参与完成的,其中有两个线程(SQL线程和IO线程)在Slave端,另一个线程(IO线程)在Master端。

master 数据变化时会产生bin log日志,slave上的线程拉去bin log,然后在slave上重新执行日志。这样就保证了数据一致性。

show slave status 中的Slave_IO_Running和Slave_SQL_Running的含义?

答:Slave 上会同时有两个线程在工作, I/O 线程从 Master 得到数据(Binary Log 文件),放到被称为

Relay Log 文件中进行记录。另一方面,SQL 线程则将 Relay Log 读取并执行。

为什么要有两个线程?这是为了降低同步的延迟。因为 I/O 线程和 SQL 线程都是相对很耗时的操作。

从服务器同步失败?

答:看错误日志 tail /var/log/mysql/error.log

重新执行同步

stop slave;

change master to master_log_file='mysql-bin.000100,master_log_pos=123'

关于 file 和 pos,需在master上执行show master status获得。

或者使用 mysqlbinlog 命令分析。

如何添加多个从节点?

和添加第一个从节点类似,先导出master的数据,复制第一个slave配置文件,唯一要改变的是server-id,不能和其他的重复。之后启动新的容器,进到容器内执行change master to ...。

还需要注意当前master没有写入等操作,最好先锁表,同步设置好后在解锁。参考

问题:

作者:飞凡的陀螺

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值