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