GTID Replication(cold start)

GTID Replication(cold start)

本文介绍如何为一个新的 MySQL 服务器配置副本,停机创建副本的场景也可参考。 Setting Up Replication Using GTIDs

环境准备

注意:MySQL版本不同,部分命令可能不同。本文使用的是8.1.0。

采用docker启动多个mysql容器来模拟一主一备的配置。

docker-compose.yml

yml 复制代码
version: '3'

services:
  mysql1:
    image: mysql:latest
    container_name: mysql-master
    ports:
      - "13306:3306" # 映射到宿主机的3306端口
    environment:
      MYSQL_ROOT_PASSWORD: root # 设置root用户的密码
    volumes:
      - ./mysql-master/conf.d:/etc/mysql/conf.d # 挂载配置文件
      - ./mysql-master/data:/var/lib/mysql # 挂载数据文件

  mysql2:
    image: mysql:latest
    container_name: mysql-slave1
    ports:
      - "13307:3306" # 映射到宿主机的3307端口
    environment:
      MYSQL_ROOT_PASSWORD: root # 设置root用户的密码
    volumes:
      - ./mysql-slave1/conf.d:/etc/mysql/conf.d # 挂载配置文件
      - ./mysql-slave1/data:/var/lib/mysql # 挂载数据文件

配置MySQL服务器

mysql-master/conf.d/my.cnf

ini 复制代码
[mysqld]
gtid_mode=ON
enforce_gtid_consistency=ON
server_id=1

mysql-slave1/conf.d/my.cnf

ini 复制代码
[mysqld]
gtid_mode=ON
enforce_gtid_consistency=ON
# server 启动时跳过开启同步任务,配置好源后,手动开启
skip_replica_start=ON
server_id=2

skip_replica_start的说明: Tells the replica server not to start the replication I/O (receiver) and SQL (applier) threads when the server starts. To start the threads later, use a START REPLICA statement.

启动MySQL并开启同步

启动服务

bash 复制代码
docker-compose up -d

登录 master, 创建同步用户账号

bash 复制代码
mysql -h 127.0.0.1 -P 13306 -u root -p
sql 复制代码
create user 'repl1'@'%' identified by 'repl1';
grant replication slave on *.* to 'repl1'@'%';

登录 slave, 配置同步源并开启同步

bash 复制代码
mysql -h 127.0.0.1 -P 13307 -u root -p

配置同步源,注意这里是通过docker-compose启动的主从节点,所以host和port的配置写成下面这样。

sql 复制代码
CHANGE REPLICATION SOURCE TO 
    SOURCE_HOST = 'mysql1', 
    SOURCE_PORT = 3306,
    SOURCE_USER = 'repl1',
    SOURCE_PASSWORD = 'repl1',
    SOURCE_AUTO_POSITION = 1,
    GET_MASTER_PUBLIC_KEY =1;

启动同步服务。

sql 复制代码
start replica

查看同步服务的状态,检查是否启动成功。

sql 复制代码
show slave status

测试同步

  1. 在master 上创建一个新的数据库 test;
  2. 在 slave 上执行 show databases,就能看到也创建了 test 数据库。
相关推荐
数据库小学妹1 小时前
数据库连接池避坑指南:告别“连接超时”与“资源耗尽”,让系统跑得更快!
数据库·redis·sql·mysql·缓存·dba
前进的李工2 小时前
EXPLAIN输出格式全解析:JSON、TREE与可视化
开发语言·数据库·mysql·性能优化·explain
达梦产品与服务2 小时前
稳扎稳打,持续迭代 | SQLark V3.10 更新,30+ 项优化与修复
mysql·oracle·达梦数据库·pg·sqlark百灵连接
shizhan_cloud4 小时前
MySQL 索引优化 + 慢查询日志
数据库·mysql
Drache_long4 小时前
MySQL数据库(故障排除)
数据库·mysql
shaoming37765 小时前
浏览器动作开发:地址栏图标点击事件、弹出页面设计
android·mysql·adb
Riu_Peter10 小时前
【技术】Docker 部署 MySQL
mysql·adb·docker
Irene199110 小时前
SQL示例:外键约束是关系型数据库中用于建立两个表之间链接的一种规则
mysql
zshs00011 小时前
从 Raft 到 MySQL:我是怎么推导出半同步复制原理的
数据库·分布式·mysql
这个DBA有点耶11 小时前
MySQL深分页优化:从LIMIT 1000000,10到毫秒级响应的三种写法
数据库·程序人生·mysql·性能优化·学习方法·dba·改行学it