注意:本教程不适用旧版本,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