Docker搭建MySQL主从复制,
Docker搭建MySQL主从复制,
Docker搭建MySQL主从复制
-
搭建主从复制数据库
3.1 配置主Master库
3.1.1 进入主库挂载配置文件my.cnf,加入以下配置并重启docker容器
[mysqld] ## 同一局域网内注意要唯一 server-id=100 ## 开启二进制日志功能,可以随便取(关键) log-bin=mysql-bin
3.1.2 在主Master库执行语句
CREATE USER 'slave'@'%' IDENTIFIED BY '123456'; GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';
为防止后面出现报错[Authentication plugin 'caching_sha2_password' cannot be loaded],执行下面语句
ALTER USER 'slave'@'%' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER; #修改加密规则 ALTER USER 'slave'@'%' IDENTIFIED WITH mysql_native_password BY 'password'; #更新一下用户的密码 FLUSH PRIVILEGES; alter user 'slave'@'%' identified by '123456';
最后执行语句获取File, Position
show master status;
3.2 配置从Slave库
3.2.1 进入从库挂载配置文件my.cnf,加入以下配置并重启docker容器
[mysqld] ## 设置server_id,注意要唯一 server-id=101 ## 开启二进制日志功能,以备Slave作为其它Slave的Master时使用 log-bin=mysql-slave-bin ## relay_log配置中继日志 relay_log=edu-mysql-relay-bin
3.2.2 链接主从库,在从库执行语句
change master to master_host='192.168.47.128', master_user='slave', master_password='123456', master_port=3306, master_log_file='mysql-bin.000001', master_log_pos= 5938, master_connect_retry=30;
master_host :Master的地址
master_port:Master的端口号,指的是容器的端口号
master_user:用于数据同步的用户
master_password:用于同步的用户的密码
master_log_file:指定 Slave 从哪个日志文件开始复制数据,即上文中提到的 File 字段的值
master_log_pos:从哪个 Position 开始读,即上文中提到的 Position 字段的值
master_connect_retry:如果连接失败,重试的时间间隔,单位是秒,默认是60秒
3.2.3 查看主从同步状态
show slave status ;
正常情况下,SlaveIORunning 和 SlaveSQLRunning 都是No,因为我们还没有开启主从复制过程。
3.2.4 开启主从复制
start slave;
重新查看主从同步状态, 这时SlaveIORunning 和 SlaveSQLRunning 都是Yes,如果你的SlaveIORunning 和 SlaveSQLRunning 其中一个是Connecting或者No,就证明配置有错,查看Last_IO_Error报错的详细信息
通过下面命令,删除已经配置的主从链接信息,重新进行配置
stop slave;
reset master;
3.2.5 测试主从复制,最简单的方式是在主库建立个新库,这时,从库会自动同步
相关文章
- 暂无相关文章
用户点评