注意:本教程不适用旧版本,Mysql 8.4.0 和 旧版本,主从复制相关命令有所变化,具体区别请看文末参考
软件版本
Docker:26.1.3
Mysql:8.4.0
GTID主从复制
1.准备主从两台服务器
2.两台服务器分别创建 docker-compose.yml 文件
services:
mysql:
image: mysql:8.4.0
ports:
- "3306:3306"
environment:
MYSQL_ROOT_PASSWORD: abc123
volumes:
- ./data:/var/lib/mysql
- ./config:/etc/mysql/conf.d
restart: always
3.主库服务器导入配置到 config/my.cnf
[mysqld]
gtid_mode=ON
enforce-gtid-consistency=ON
4.从库服务器导入配置到 config/my.cnf
[mysqld]
gtid_mode=ON
enforce-gtid-consistency=ON
server-id = 2
5.启动两个容器
6.主库创建复制账户
CREATE USER 'repl' IDENTIFIED BY 'abc123';
GRANT REPLICATION SLAVE ON *.* TO 'repl';
7.从库接入
7.1.配置复制源:
CHANGE REPLICATION SOURCE TO
SOURCE_HOST = '192.168.1.113',
SOURCE_PORT = 3306,
SOURCE_USER = 'repl',
SOURCE_PASSWORD = 'abc123',
SOURCE_AUTO_POSITION = 1,
SOURCE_SSL = 1;
7.2.启动复制进程:START REPLICA;
7.3.查看复制状态:SHOW REPLICA STATUS;
主要看这两个,都是Yes代表就绪
(扩展)停止重置复制:STOP REPLICA;
RESET REPLICA ALL;
8.主从复制配置完毕
接下来所有主库的变化都会同步到从库,但是要注意,从库非只读状态,要杜绝直接修改从库,否则可能会导致冲突。
传统主从复制
1.准备主从两台服务器
2.两台服务器分别创建 docker-compose.yml 文件
services:
mysql:
image: mysql:8.4.0
ports:
- "3306:3306"
environment:
MYSQL_ROOT_PASSWORD: abc123
volumes:
- ./data:/var/lib/mysql
- ./config:/etc/mysql/conf.d
restart: always
3.从库服务器导入配置到 config/my.cnf
[mysqld]
server-id = 2
4.启动两个容器
5.主库创建复制账户
CREATE USER 'repl' IDENTIFIED BY 'abc123';
GRANT REPLICATION SLAVE ON *.* TO 'repl';
5.查看主库日志文件名、指针
执行SQL:SHOW BINARY LOG STATUS;
6.从库接入
6.1.配置复制源:
填入主库的文件名、指针
CHANGE REPLICATION SOURCE TO
SOURCE_HOST='192.168.1.113',
SOURCE_USER='repl',
SOURCE_PASSWORD='abc123',
SOURCE_LOG_FILE='binlog.000002',
SOURCE_LOG_POS=682,
SOURCE_SSL = 1;
6.2.启动复制进程:START REPLICA;
6.3.查看复制状态:SHOW REPLICA STATUS;
主要看这两个,都是Yes代表就绪
(扩展)停止重置复制:STOP REPLICA;
RESET REPLICA ALL;
7.主从复制配置完毕
接下来所有主库的变化都会同步到从库,但是要注意,从库非只读状态,要杜绝直接修改从库,否则可能会导致冲突。
参考
MySQL :: MySQL 8.4 Reference Manual :: 19.1.2 Setting Up Binary Log File Position Based Replication
MySQL :: MySQL 8.4 Reference Manual :: 19.1.3.4 Setting Up Replication Using GTIDs
MySQL 8.4.0 LTS 变更解析:MySQL 的复制与组复制 – 墨天轮 (modb.pro)
1.本站内容仅供参考,不作为任何法律依据。用户在使用本站内容时,应自行判断其真实性、准确性和完整性,并承担相应风险。
2.本站部分内容来源于互联网,仅用于交流学习研究知识,若侵犯了您的合法权益,请及时邮件或站内私信与本站联系,我们将尽快予以处理。
3.本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
4.根据《计算机软件保护条例》第十七条规定“为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。”您需知晓本站所有内容资源均来源于网络,仅供用户交流学习与研究使用,版权归属原版权方所有,版权争议与本站无关,用户本人下载后不能用作商业或非法用途,需在24个小时之内从您的电脑中彻底删除上述内容,否则后果均由用户承担责任;如果您访问和下载此文件,表示您同意只将此文件用于参考、学习而非其他用途,否则一切后果请您自行承担,如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。
5.本站是非经营性个人站点,所有软件信息均来自网络,所有资源仅供学习参考研究目的,并不贩卖软件,不存在任何商业目的及用途
暂无评论内容