Mysql 8.4.0 結合 Docker 搭建GTID主從複製,以及傳統主從複製

Yfeil發表於2024-06-07

注意:本教程不適用舊版本,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代表就緒

Mysql 8.4.0 結合 Docker 搭建GTID主從複製,以及傳統主從複製

(擴充套件)停止重置複製: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;

Mysql 8.4.0 結合 Docker 搭建GTID主從複製,以及傳統主從複製

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代表就緒

Mysql 8.4.0 結合 Docker 搭建GTID主從複製,以及傳統主從複製

(擴充套件)停止重置複製: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)

相關文章