Mysql 8.4.0 结合 Docker 搭建GTID主从复制,以及传统主从复制
|
注意:本教程不适用旧版本,Mysql 8.4.0 和 旧版本,主从复制相关命令有所变化,具体区别请看文末参考
软件版本
Docker:26.1.3
Mysql:8.4.0
GTID主从复制
1.准备主从两台服务器
2.两台服务器分别创建DockerCompose文件
- 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=ONserver-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.两台服务器分别创建DockerCompose文件
- 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
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)
来源:https://www.cnblogs.com/yfeil/p/18237529
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
x
|
|
|
发表于 2024-6-7 21:48:11
举报
回复
分享
|
|
|
|