Mysql 8.4.0 结合 Docker 搭建GTID主从复制及传统主从复制详解

 更新时间:2024年06月09日 10:46:35   作者:羽飞落  
这篇文章主要介绍了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=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.两台服务器分别创建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]
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)

到此这篇关于Mysql 8.4.0 结合 Docker 搭建GTID主从复制,以及传统主从复制的文章就介绍到这了,更多相关Mysql 8.4.0 主从复制内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL中的当前读和快照读的区别

    MySQL中的当前读和快照读的区别

    在MySQL中,当前读和快照读是事务中的两种重要的读取方式,当前读,即锁定读,会对读取的行记录加锁,确保数据一致性,两者的主要区别在于锁定机制、数据一致性、并发性能和幻读问题,理解这些差异有助于根据业务需求选择合适的读取方式,保证数据库的事务隔离性和一致性
    2024-09-09
  • mysql 如何获取两个集合的交集/差集/并集

    mysql 如何获取两个集合的交集/差集/并集

    这篇文章主要介绍了mysql获取两个集合的交集/差集/并集操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • Mybatis mapper动态代理的原理解析

    Mybatis mapper动态代理的原理解析

    这篇文章主要介绍了Mybatis mapper动态代理的原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08
  • IDEA连接mysql时区问题解决

    IDEA连接mysql时区问题解决

    在使用MySQL数据库时,经常会遇到需要设置时区的情况,本文主要介绍了IDEA连接mysql时区问题解决,具有一定的参考价值,感兴趣的可以了解一下
    2024-06-06
  • MySQL 中 datetime 和 timestamp 的区别与选择

    MySQL 中 datetime 和 timestamp 的区别与选择

    MySQL 中常用的两种时间储存类型分别是datetime和 timestamp。如何在它们之间选择是建表时必要的考虑。下面就谈谈他们的区别和怎么选择,需要的朋友可以参考一下
    2021-09-09
  • mysql字符集乱码问题解决方法介绍

    mysql字符集乱码问题解决方法介绍

    解决乱码的方法是,在执行SQL语句之前,将MySQL以下三个系统参数设置为与服务器字符集character-set-server相同的字符集
    2012-05-05
  • MySQL数据库导入导出数据之报错解答实例讲解

    MySQL数据库导入导出数据之报错解答实例讲解

    这篇文章主要介绍了MySQL数据库导入导出数据之报错解答实例讲解,文中对报错和解决方法做了详细的实例展示,有需要的同学可以借鉴参考下
    2021-02-02
  • 一条sql详解MYSQL的架构设计详情

    一条sql详解MYSQL的架构设计详情

    这篇文章主要介绍了一条sql详解MYSQL的架构设计详情,文章围绕主题展开详细的内容介绍,具有一定的参考价值,感兴趣的小伙伴可以参考一下
    2022-09-09
  • Mysql大表全表update的的实现

    Mysql大表全表update的的实现

    有些时候在进行一些业务迭代时需要我们对Mysql表中数据进行全表update,本文主要介绍了Mysql大表update的的实现
    2024-08-08
  • MySQL查询缓存优化示例详析

    MySQL查询缓存优化示例详析

    MySQL的优化指的是一个很大的系统,面试的时候我之前是从sql的语句优化方面去说的,这种优化也有作用,不过是从逻辑方面去优化,下面这篇文章主要给大家介绍了关于MySQL查询缓存优化的相关资料,需要的朋友可以参考下
    2022-10-10

最新评论