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
测试同步
- 在master 上创建一个新的数据库
test
; - 在 slave 上执行
show databases
,就能看到也创建了test
数据库。