Mysql 8.4.0 結(jié)合 Docker 搭建GTID主從復(fù)制,以及傳統(tǒng)主從復(fù)制
注意:本教程不適用舊版本,Mysql 8.4.0 和 舊版本,主從復(fù)制相關(guān)命令有所變化,具體區(qū)別請(qǐng)看文末參考
軟件版本
Docker:26.1.3
Mysql:8.4.0
GTID主從復(fù)制
1.準(zhǔn)備主從兩臺(tái)服務(wù)器
2.兩臺(tái)服務(wù)器分別創(chuàng)建 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.主庫(kù)服務(wù)器導(dǎo)入配置到 config/my.cnf
[mysqld]
gtid_mode=ON
enforce-gtid-consistency=ON
4.從庫(kù)服務(wù)器導(dǎo)入配置到 config/my.cnf
[mysqld]
gtid_mode=ON
enforce-gtid-consistency=ON
server-id = 2
5.啟動(dòng)兩個(gè)容器
6.主庫(kù)創(chuàng)建復(fù)制賬戶
CREATE USER 'repl' IDENTIFIED BY 'abc123';
GRANT REPLICATION SLAVE ON *.* TO 'repl';
7.從庫(kù)接入
7.1.配置復(fù)制源:
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.啟動(dòng)復(fù)制進(jìn)程:START REPLICA;
7.3.查看復(fù)制狀態(tài):SHOW REPLICA STATUS;
主要看這兩個(gè),都是Yes代表就緒
![]()
(擴(kuò)展)停止重置復(fù)制:STOP REPLICA;RESET REPLICA ALL;
8.主從復(fù)制配置完畢
接下來(lái)所有主庫(kù)的變化都會(huì)同步到從庫(kù),但是要注意,從庫(kù)非只讀狀態(tài),要杜絕直接修改從庫(kù),否則可能會(huì)導(dǎo)致沖突。
傳統(tǒng)主從復(fù)制
1.準(zhǔn)備主從兩臺(tái)服務(wù)器
2.兩臺(tái)服務(wù)器分別創(chuàng)建 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.從庫(kù)服務(wù)器導(dǎo)入配置到 config/my.cnf
[mysqld]
server-id = 2
4.啟動(dòng)兩個(gè)容器
5.主庫(kù)創(chuàng)建復(fù)制賬戶
CREATE USER 'repl' IDENTIFIED BY 'abc123';
GRANT REPLICATION SLAVE ON *.* TO 'repl';
5.查看主庫(kù)日志文件名、指針
執(zhí)行SQL:SHOW BINARY LOG STATUS;
![]()
6.從庫(kù)接入
6.1.配置復(fù)制源:
填入主庫(kù)的文件名、指針
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.啟動(dòng)復(fù)制進(jìn)程:START REPLICA;
6.3.查看復(fù)制狀態(tài):SHOW REPLICA STATUS;
主要看這兩個(gè),都是Yes代表就緒
![]()
(擴(kuò)展)停止重置復(fù)制:STOP REPLICA;RESET REPLICA ALL;
7.主從復(fù)制配置完畢
接下來(lái)所有主庫(kù)的變化都會(huì)同步到從庫(kù),但是要注意,從庫(kù)非只讀狀態(tài),要杜絕直接修改從庫(kù),否則可能會(huì)導(dǎo)致沖突。
參考
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
浙公網(wǎng)安備 33010602011771號(hào)