MySQL克隆庫(kù)是一種特殊的MySQL備份,它不同于普通備份,可以提供多種優(yōu)秀功能。它可以非常簡(jiǎn)單地實(shí)現(xiàn)數(shù)據(jù)庫(kù)的高可用性,也可以用于數(shù)據(jù)庫(kù)的異地容災(zāi),不同的克隆庫(kù)可以在不同的地方、不同的計(jì)算機(jī)甚至不同的數(shù)據(jù)中心內(nèi)實(shí)現(xiàn)高可用性。下面我們將介紹如何使用MySQL克隆庫(kù)。
mysqldump --opt --single-transaction --master-data=2 -hsource_host
-usource_user
-psource_passwd
source_db
mysql -hdestination_host
-udestination_user
-pdestination_passwd
destination_db
以上代碼是使用mysqldump命令進(jìn)行克隆的方法,以下是詳細(xì)步驟:
1.首先在目標(biāo)主機(jī)上創(chuàng)建一個(gè)空白的數(shù)據(jù)庫(kù)。
2.在源服務(wù)器上執(zhí)行以下命令來(lái)創(chuàng)建克隆數(shù)據(jù)庫(kù)的轉(zhuǎn)儲(chǔ),并將數(shù)據(jù)導(dǎo)入新的數(shù)據(jù)庫(kù):
mysqldump --opt --single-transaction --master-data=2 -hsource_host
-usource_user
-psource_passwd
source_db
mysql -hdestination_host
-udestination_user
-pdestination_passwd
destination_db
3.在目標(biāo)服務(wù)器上執(zhí)行以下命令,將從源服務(wù)器的MySQL服務(wù)器端口復(fù)制二進(jìn)制日志文件到目標(biāo)服務(wù)器:
mysqlbinlog --read-from-remote-server --host=source_host
-usource_user
-psource_passwd
mysql-bin.000XXX | mysql -hdestination_host
-udestination_user
-pdestination_passwd
destination_db
這些命令可以將源服務(wù)器上的庫(kù)完整地復(fù)制到目標(biāo)服務(wù)器上,在方便后期的數(shù)據(jù)同步和更新。
在MySQL中有一個(gè)重要的概念是“復(fù)制”。MySQL復(fù)制是一種將多個(gè)服務(wù)器上的數(shù)據(jù)同步的技術(shù)。MySQL復(fù)制具有以下三個(gè)關(guān)鍵組成部分:
- 主庫(kù)(master) - 主要的寫(xiě)入節(jié)點(diǎn),原始數(shù)據(jù)是從這里開(kāi)始的;
- 備庫(kù)(slaves) - 從主庫(kù)復(fù)制數(shù)據(jù)的節(jié)點(diǎn),其擁有的數(shù)據(jù)與主庫(kù)同步;
- 復(fù)制程序(replication) - 同步主庫(kù)和備庫(kù)之間的數(shù)據(jù)的程序,負(fù)責(zé)復(fù)制數(shù)據(jù)。
在MySQL復(fù)制中,主庫(kù)將寫(xiě)入的數(shù)據(jù)通過(guò)二進(jìn)制日志傳輸?shù)絺鋷?kù),備庫(kù)在接收到日志后,將其應(yīng)用到自己的數(shù)據(jù)文件中。備庫(kù)會(huì)在一定的間隔時(shí)間內(nèi),定期將接收到的日志存儲(chǔ)到硬盤(pán)中。
由于MySQL復(fù)制的這種架構(gòu)只需將數(shù)據(jù)復(fù)制到備庫(kù),而不需要進(jìn)行其他操作,因此不會(huì)影響生產(chǎn)環(huán)境的性能。這正是MySQL復(fù)制在數(shù)據(jù)備份和災(zāi)難恢復(fù)方面的優(yōu)勢(shì)。