mysql常用的三種備份方法

2021-09-22 05:10:56 字數 2450 閱讀 5409

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(推薦)

1.完全備份整個資料庫

innobackupex --user=root --password=123456 /tmp/backup

此時會在/tmp/backup目錄下生成以時間為名的資料夾,裡面是備份檔案

在這裡,備份的資料還不能直接用來還原,因為備份資料中會含有尚未提交的事務或者未同步到資料檔案中的事物。這裡需要用prepare回滾事物使資料檔案處於一致性。

處理完成後才能用來還原資料,用此命令還原

innobackupex --copy-back /tmp/backup/dir

要實現時間點還原,還是需要使用二進位制日誌

2.增量備份

增量備份支援innodb,對於myisam只能完全備份

innobackupex –incremental /tmp/backup/incremental --incremental-basedir=/tmp/backup/dir

在進行一次增量備份--incremental-basedir要指向上一次增量備份的目錄

如果要進行還原,先進行prepare處理

這裡處理的方式,將備份合併

最後使用完全備份的那個備份還原

至於差異備份,只要每次將basedir指向完全備份檔案夾就行了

最後再廢話一句:要實現時間點還原,是需要使用二進位制日誌的,所以備份好二進位制日誌至關重要。除非在恢復時間點和上一次備份時間點這段時間的資料對你來說無所謂。。。

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...