MySQL 遷移無非是圍繞著數(shù)據(jù)做工作,再繼續(xù)延伸,無非就是在保證業(yè)務(wù)平穩(wěn)持續(xù)地運(yùn)行的前提下做備份恢復(fù)。那問題就在怎么快速安全地進(jìn)行備份恢復(fù)。
一方面,備份。針對每個主節(jié)點的從節(jié)點或者備節(jié)點,都有備份。這個備份可能是全備,可能是增量備份。在線備份的方法,可能是使用 mysqldump,可能是 xtrabackup,還可能是 mydumper。針對小容量(10GB 以下)數(shù)據(jù)庫的備份,我們可以使用 mysqldump。但針對大容量數(shù)據(jù)庫(數(shù)百GB 或者 TB 級別),我們不能使用 mysqldump 備份,一方面,會產(chǎn)生鎖;另一方面,耗時太長。這種情況,可以選擇 xtrabackup 或者直接拷貝數(shù)據(jù)目錄。直接拷貝數(shù)據(jù)目錄方法,不同機(jī)器傳輸可以使用 rsync,耗時跟網(wǎng)絡(luò)相關(guān)。使用 xtrabackup,耗時主要在備份和網(wǎng)絡(luò)傳輸。如果有全備或者指定庫的備份文件,這是獲取備份的最好方法。如果備庫可以容許停止服務(wù),直接拷貝數(shù)據(jù)目錄是最快的方法。如果備庫不允許停止服務(wù),我們可以使用 xtrabackup(不會鎖定 InnoDB 表),這是完成備份的最佳折中辦法。
另一方面,恢復(fù)。針對小容量(10GB 以下)數(shù)據(jù)庫的備份文件,我們可以直接導(dǎo)入。針對大容量數(shù)據(jù)庫(數(shù)百GB 或者 TB 級別)的恢復(fù),拿到備份文件到本機(jī)以后,恢復(fù)不算困難。具體的恢復(fù)方法可以參考第四節(jié)。
更多建議: