MySQL 復制是 MySQL 數據庫管理員經常使用的工具,可以用來復制 MySQL 數據庫的一個或多個庫到其他的 MySQL 服務器上。這種技術可以用于數據備份、負載平衡和安全性等方面。
下面是一個簡單的 MySQL 復制示例,假設我們希望將一個名為 "mydb" 的數據庫從主服務器復制到另一個服務器(即備份服務器)上:
# 在主服務器上執行以下命令:
mysql>GRANT REPLICATION SLAVE ON *.* TO 'slave_user'@'%' IDENTIFIED BY 'password';
mysql>FLUSH TABLES WITH READ LOCK;
# 獲取當前主服務器的位置信息
mysql>SHOW MASTER STATUS;
# 記下 File 和 Position 的值(稍后需要用到)
# 在備份服務器上執行以下命令:
mysql>CHANGE MASTER TO
->MASTER_HOST='<主服務器 IP 地址>',
->MASTER_USER='',
->MASTER_PASSWORD='',
->MASTER_LOG_FILE='',
->MASTER_LOG_POS=;
mysql>START SLAVE;
上面的命令執行了以下步驟:
- 在主服務器上,我們將創建一個名為 "slave_user" 的用戶,并允許該用戶使用 MySQL 復制功能。因此,從服務器可以使用該用戶進行備份。
- 我們使用 FLUSH TABLES WITH READ LOCK 命令鎖定了主服務器的所有表。
- 我們使用 SHOW MASTER STATUS 命令獲取了主服務器當前的 MySQL 二進制日志的位置信息。稍后,我們將使用這些信息來創建從服務器的復制進程。
- 在備份服務器上,我們使用 CHANGE MASTER TO 命令將從服務器連接到主服務器。
- 最后,我們使用 START SLAVE 命令啟動從服務器的復制進程。
現在,備份服務器將開始從主服務器復制 "mydb" 數據庫。如果您需要定期地備份 MySQL 數據庫,請在從服務器上執行相應的備份操作。