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

打印 上一主题 下一主题

主题 1376|帖子 1376|积分 4128

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
注意:本教程不适用旧版本,Mysql 8.4.0 和 旧版本,主从复制相关命令有所变化,具体区别请看文末参考
软件版本

Docker:26.1.3
Mysql:8.4.0
 
GTID主从复制

1.准备主从两台服务器

2.两台服务器分别创建DockerCompose文件
  1. services:
  2.   mysql:
  3.     image: mysql:8.4.0
  4.     ports:
  5.       - "3306:3306"
  6.     environment:
  7.       MYSQL_ROOT_PASSWORD: abc123
  8.     volumes:
  9.       - ./data:/var/lib/mysql
  10.       - ./config:/etc/mysql/conf.d
  11.     restart: always
复制代码
3.主库服务器导入设置到 config/my.cnf
  1. [mysqld]
  2. gtid_mode=ON
  3. enforce-gtid-consistency=ON
复制代码
4.从库服务器导入设置到 config/my.cnf
  1. [mysqld]
  2. gtid_mode=ON
  3. enforce-gtid-consistency=ONserver-id = 2
复制代码
5.启动两个容器

6.主库创建复制账户
  1. CREATE USER 'repl' IDENTIFIED BY 'abc123';
  2. GRANT REPLICATION SLAVE ON *.* TO 'repl';
复制代码
7.从库接入

7.1.设置复制源:
  1. CHANGE REPLICATION SOURCE TO
  2. SOURCE_HOST = '192.168.1.113',
  3. SOURCE_PORT = 3306,
  4. SOURCE_USER = 'repl',
  5. SOURCE_PASSWORD = 'abc123',
  6. SOURCE_AUTO_POSITION = 1,
  7. SOURCE_SSL = 1;
复制代码
7.2.启动复制进程:START REPLICA;
7.3.查看复制状态:SHOW REPLICA STATUS;
主要看这两个,都是Yes代表就绪

(扩展)制止重置复制:STOP REPLICA;RESET REPLICA ALL;
8.主从复制设置完毕

接下来所有主库的变化都会同步到从库,但是要注意,从库非只读状态,要杜绝直接修改从库,否则可能会导致冲突。
 
传统主从复制

1.准备主从两台服务器

2.两台服务器分别创建DockerCompose文件
  1. services:
  2.   mysql:
  3.     image: mysql:8.4.0
  4.     ports:
  5.       - "3306:3306"
  6.     environment:
  7.       MYSQL_ROOT_PASSWORD: abc123
  8.     volumes:
  9.       - ./data:/var/lib/mysql
  10.       - ./config:/etc/mysql/conf.d
  11.     restart: always
复制代码
3.从库服务器导入设置到 config/my.cnf
  1. [mysqld]
  2. server-id = 2
复制代码
4.启动两个容器

5.主库创建复制账户
  1. CREATE USER 'repl' IDENTIFIED BY 'abc123';
  2. GRANT REPLICATION SLAVE ON *.* TO 'repl';
复制代码
5.查看主库日志文件名、指针

执行SQL:SHOW BINARY LOG STATUS;

6.从库接入

6.1.设置复制源:
填入主库的文件名、指针
  1. CHANGE REPLICATION SOURCE TO
  2. SOURCE_HOST='192.168.1.113',
  3. SOURCE_USER='repl',
  4. SOURCE_PASSWORD='abc123',
  5. SOURCE_LOG_FILE='binlog.000002',
  6. SOURCE_LOG_POS=682,
  7. 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)

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

光之使者

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表