Mysql 8.4.0 结合 Docker 搭建GTID主从复制,以及传统主从复制

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Yfeil

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值