MySQL 5.7 是一個(gè)功能強(qiáng)大且廣泛使用的關(guān)系型數(shù)據(jù)庫(kù)。在實(shí)際的應(yīng)用中,我們經(jīng)常需要將多個(gè) MySQL 實(shí)例的數(shù)據(jù)同步起來(lái),以實(shí)現(xiàn)高可用性以及負(fù)載均衡的目的。其中,主從同步就是一種常見(jiàn)的數(shù)據(jù)同步方式。
在 MySQL 5.7 中,主從同步不僅可以同步最新的數(shù)據(jù),還支持同步歷史數(shù)據(jù)。當(dāng)數(shù)據(jù)在主庫(kù)中被刪除或者修改時(shí),從庫(kù)同樣可以記錄并同步這些歷史數(shù)據(jù),以保證數(shù)據(jù)的完整性和一致性。
## 主庫(kù)配置
# 在 my.cnf 中添加如下配置
server-id = 1
log-bin = mysql-bin
binlog-format = ROW
binlog-row-image = full
## 從庫(kù)配置
# 在 my.cnf 中添加如下配置
server-id = 2
relay-log = mysql-relay
relay-log-index = mysql-relay.index
relay-log-info-file = relay-log.info
slave-parallel-workers = 4
read-only = 1
## 開(kāi)啟主從同步
# 在主庫(kù) MySQL shell 中執(zhí)行如下命令
CREATE USER 'repl'@'%' IDENTIFIED BY 'password';
GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%' IDENTIFIED BY 'password';
FLUSH PRIVILEGES;
# 在從庫(kù) MySQL shell 中執(zhí)行如下命令
CHANGE MASTER TO
MASTER_HOST='master_host',
MASTER_USER='repl',
MASTER_PASSWORD='password',
MASTER_LOG_FILE='mysql-bin.000001',
MASTER_LOG_POS=0;
START SLAVE;
以上代碼展示了如何在 MySQL 5.7 中進(jìn)行主從同步的相關(guān)配置和命令。其中,主庫(kù)需要配置 log-bin 和 binlog-format 參數(shù),從庫(kù)需要執(zhí)行 CHANGE MASTER TO 命令,指定主庫(kù)的相關(guān)信息進(jìn)行連接。
主從同步不僅可以保證數(shù)據(jù)的實(shí)時(shí)同步,還可以同步歷史數(shù)據(jù),以保證數(shù)據(jù)的完整性和一致性。在實(shí)際的應(yīng)用中,我們可以根據(jù)業(yè)務(wù)需求選擇是否啟用歷史數(shù)據(jù)同步,以達(dá)到更好的效果。