MySQL常用的三種備份方法

2021-09-20 17:21:02 字數 1884 閱讀 2523

mysql按照備份恢復方式分為邏輯備份和物理備份。邏輯備份是備份sql語句,在恢復的時候執行備份的sql語句實現資料庫資料的重現,物理備份就是備份資料檔案了,比較形象點就是cp下資料檔案,但真正備份的時候自然不是的cp這麼簡單。

這2種備份各有優劣,一般來說,物理備份恢復速度比較快,占用空間比較大,邏輯備份速度比較慢,占用空間比較小

下面介紹以下3種常用的備案方法

一、mysqldump工具備份

mysqldump由於是mysql自帶的備份工具,所以也是最常用的mysql資料庫的備份工具。支援基於innodb的熱備份。但由於是邏輯備份,所以速度不是很快,適合備份資料量比較小的場景。

mysqldump完全備份+二進位制日誌 —>實現時間點恢復

溫備:

在使用myisam引擎中,只能使用溫備份,這時候要防止資料的寫入,所以先加上讀鎖

這時候可以進入資料庫手動加讀鎖。這樣比較麻煩,在mysqldump工具中直接有乙個加鎖的選項

mysqldump --databases mydatabase --lock-all-tables --flush-logs> /tmp/backup-`date +%f-%h-%m`.sql

如果是針對某張表備份,只要在資料庫名稱後面加上表名稱就行了

這裡注意,要實現時間點的恢復,加上--flush-logs選項,在使用備份檔案恢復後,然後再基於二進位制日誌進行時間點的恢復時間點的恢復方法

mysqlbinlog mysql-bin.000000x > /tmp/pointtime.sql

然後用mysql命令匯入這個sql指令碼就行了

熱備:如果使用的是innodb引擎,就不必進行對資料庫加鎖的操作,加乙個選項既可以進行熱備份:--single-transaction

mysqldump --databases mydb --single-transaction --flush-logs --master-data=2 > /tmp/backup-`date +%f-%h-%m`.sql

注意點

恢復的時刻關閉二進位制日誌

mysql>set sql_log_bin=0;

因為這是基於邏輯備份方式,在恢復日誌時會執行sql語句插入資料,而恢復時候插入資料的日誌沒有意義。

二、基於lvm快照備份

在物理備份中 ,有基於檔案系統的物理備份(lvm的快照),也可以直接用tar之類的命令打包。但這些只能進行冷備份

不同的儲存引擎能備份的級別也不一樣,myisam能備份到表級別,而innodb不開啟每表一檔案的話就只能備份整個資料庫。

下面就介紹下使用lvm的快照功能進行備份

為了安全 首先在資料庫上施加讀鎖

mysql>flush tables with read lock;

重新整理一下二進位制日誌,便於做時間點恢復

mysql>flush logs;

然後建立快照卷

lvcreate –l 1g –s –n data-snap –p –r /dev/myvg/mydata

最後進入資料庫釋放讀鎖

unlock tables;

掛載快照卷進行備份

mount –r /dev/myvg/data-snap /mnt/snap

然後對/mnt/snap下的檔案進行打包備份

還原的時候,關閉mysqld,然後備份二進位制日誌後將原來備份的檔案還原進去,然後通過二進位制日誌還原到出錯的時間(通過二進位制還原時間點的時候不要忘了暫時關閉二進位制日誌)

三、使用percona提供的xtrabackup(推薦)

參考資料:

mysql常用的三種備份方法

mysql按照備份恢復方式分為邏輯備份和物理備份 邏輯備份是備份sql語句,在恢復的時候執行備份的sql語句實現資料庫資料的重現 物理備份就是備份資料檔案了,比較形象點就是cp下資料檔案,但真正備份的時候自然不是的cp這麼簡單 這2種備份各有優劣,一般來說,物理備份恢復速度比較快,占用空間比較大,邏...

mysql常用的三種備份方法

mysql按照備份恢復方式分為邏輯備份和物理備份 邏輯備份是備份sql語句,在恢復的時候執行備份的sql語句實現資料庫資料的重現 物理備份就是備份資料檔案了,比較形象點就是cp下資料檔案,但真正備份的時候自然不是的cp這麼簡單 這2種備份各有優劣,一般來說,物理備份恢復速度比較快,占用空間比較大,邏...

mysql事件備份 MySQL三種備份

一 備份分類 二 備份工具mysqldump講解 mysqldump三種備份方式 第一種 備份 root station141 mysqldump databases benet tmp benet.sql mysql unlock tables 解鎖 mysql drop database ben...