MySQL多主一從同步配置是一種數據同步方案,可以保證多個MySQL數據庫服務器之間數據的一致性和可靠性。這種方案的實現關鍵在于MySQL的復制機制,主要步驟如下:
1.在每個主庫的my.cnf配置文件中添加如下配置:
server_id=1 log_bin=mysql-bin binlog_do_db=mydb
其中server_id是唯一的,用于標識不同的主庫實例;log_bin表示開啟binlog;binlog_do_db表示指定要同步的數據庫,這里是mydb。
2.在從庫的my.cnf配置文件中添加如下配置:
server_id=2 log_bin=mysql-bin binlog_do_db=mydb relay_log=mysql-relay-bin log_slave_updates=1
其中server_id也是唯一的,和主庫不同;log_bin和binlog_do_db與主庫相同;relay_log表示開啟中繼日志;log_slave_updates表示允許從庫將更新的數據再次同步到主庫。
3.在主庫上添加從庫賬號,并授權:
GRANT REPLICATION SLAVE ON *.* TO 'slave'@'192.168.0.2' IDENTIFIED BY 'slavepassword';
其中192.168.0.2是從庫的IP地址,slavepassword是從庫與主庫之間的密碼。
4.在從庫上執行如下命令開始同步:
CHANGE MASTER TO MASTER_HOST='192.168.0.1', MASTER_USER='slave', MASTER_PASSWORD='slavepassword', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=4; START SLAVE;
其中MASTER_HOST、MASTER_USER、MASTER_PASSWORD是主庫的IP地址、從庫賬號和密碼;MASTER_LOG_FILE和MASTER_LOG_POS分別是主庫當前的binlog文件和位置。
5.如果需要添加更多的主庫,重復步驟1-4即可。
通過以上步驟,多個主庫之間的數據同步就已經配置完成了。在實際的生產環境中,還需要考慮如何避免主從同步出現延遲或者同步錯誤的情況,以及如何處理幾個主庫同時對同一個數據表修改的沖突。