數(shù)據(jù)庫崩潰,利用備份和日志進行災難恢復
更新時間:2015年07月23日 10:35:05 作者:xcga_wise
我相信數(shù)據(jù)庫崩潰都不是大家所愿意看到的,但是這種情況發(fā)生時我們要采取補救措施,本文就是介紹了如何利用備份和日志進行災難恢復,需要的朋友可以參考下
在實際的工作中,我們可能經(jīng)常會遇到數(shù)據(jù)庫宕機,數(shù)據(jù)丟失的情況,下面,我將演示一個模擬環(huán)境
1.數(shù)據(jù)庫正常啟動插入數(shù)據(jù):
[root@client103 ~]# mysql -uroot -pkongzhong mysql> use test; mysql> insert into a select * from a; #注: 這里不演示建表,默認大家都懂 # 下面進行一次全備 [root@client103 ~]# innobackupex --user=root --password=kongzhong --defaults-file=/etc/my.cnf --port=3306 /tmp/backup/ >/tmp/backup/innoback.log 2>&1 # 再次插入數(shù)據(jù) mysql> insert into a select * from a; # 實行增量備份 [root@client103 ~]# innobackupex --user=root --password=kongzhong --defaults-file=/etc/my.cnf --port=3306 --incremental --incremental-basedir=/tmp/backup/2014-02-27_13-24-51/ /tmp/backup/ # 再次插入數(shù)據(jù) mysql> insert into a select * from a; # 此時大家記錄一下現(xiàn)在的總行數(shù)(一會還原需要核對數(shù)據(jù)的) # 此時數(shù)據(jù)庫宕機 #模擬宕機操作為: # 1.將數(shù)據(jù)目錄的下的二進制日志,復制到 /tmp/backup,一會需要重演日志(此步非常重要,復制操作默認大家會了) # 2.刪除數(shù)據(jù)目錄下的所有文件,此時數(shù)據(jù)庫就崩潰了(如果關閉數(shù)據(jù)庫,是關不了,記得殺掉進程,kill -9 ....)
2.數(shù)據(jù)庫宕機后執(zhí)行恢復操作
在實際的工作中,我們可能經(jīng)常會遇到數(shù)據(jù)庫宕機,數(shù)據(jù)丟失的情況,下面,我將演示一個模擬環(huán)境 1.數(shù)據(jù)庫正常啟動插入數(shù)據(jù): [root@client103 ~]# mysql -uroot -pkongzhong mysql> use test; mysql> insert into a select * from a; #注: 這里不演示建表,默認大家都懂 # 下面進行一次全備 [root@client103 ~]# innobackupex --user=root --password=kongzhong --defaults-file=/etc/my.cnf --port=3306 /tmp/backup/ >/tmp/backup/innoback.log 2>&1 # 再次插入數(shù)據(jù) mysql> insert into a select * from a; # 實行增量備份 [root@client103 ~]# innobackupex --user=root --password=kongzhong --defaults-file=/etc/my.cnf --port=3306 --incremental --incremental-basedir=/tmp/backup/2014-02-27_13-24-51/ /tmp/backup/ # 再次插入數(shù)據(jù) mysql> insert into a select * from a; # 此時大家記錄一下現(xiàn)在的總行數(shù)(一會還原需要核對數(shù)據(jù)的) # 此時數(shù)據(jù)庫宕機 #模擬宕機操作為: # 1.將數(shù)據(jù)目錄的下的二進制日志,復制到 /tmp/backup,一會需要重演日志(此步非常重要,復制操作默認大家會了) # 2.刪除數(shù)據(jù)目錄下的所有文件,此時數(shù)據(jù)庫就崩潰了(如果關閉數(shù)據(jù)庫,是關不了,記得殺掉進程,kill -9 ....) 2.數(shù)據(jù)庫宕機后執(zhí)行恢復操作 # 全備應用日志 [root@client103 ~]# innobackupex --apply-log /tmp/backup/2014-02-27_13-24-51/ # 增備應用日志 [root@client103 ~]# innobackupex --apply-log /tmp/backup/2014-02-27_13-24-51/ --incremental-dir=/tmp/backup/2014-02-27_13-32-44/ # 應用完日志,利用全備恢復數(shù)據(jù) [root@client103 ~]# innobackupex --copy-back /tmp/backup/2014-02-27_13-24-51/ # 修改數(shù)據(jù)目錄權限為mysql:mysql [root@client103 ~]# chown mysq:mysql /var/lib/mysql -R # 啟動數(shù)據(jù)庫 [root@client103 ~]# /etc/init.d/mysql start # 登陸數(shù)據(jù)庫,查看數(shù)據(jù)行數(shù),發(fā)現(xiàn)數(shù)值與崩潰前是不一致的,所以需要利用日志恢復 [root@client103 ~]# mysql -uroot -pkongzhong mysql> use test; mysql> select count(*) from a; # 查看最后一次增備完成時的日志文件名和pos號(備份時自動記錄的) [root@client103 ~]# cat /tmp/backup/2014-02-27_13-32-44/xtrabackup_binlog_info mysql-103-bin.000005 3694 # 所以,我們使用二進制執(zhí)行恢復時,起始點為3694 # 利用日志恢復 [root@client103 ~]# mysqlbinlog --start-pos=3694 /tmp/backup/mysql-103-bin.000005 |mysql -uroot -pkongzhong # 此時在登陸數(shù)據(jù)庫查看數(shù)據(jù)是否相符,請自行測試 mysql> use test; mysql> select count(*) from a;
以上就是本文的全部內(nèi)容,希望大家可以喜歡。
您可能感興趣的文章:
- 定時自動備份IIS的WWW日志的vbs腳本
- mssql自動備份及自動清除日志文件服務器設置
- sqlserver 數(shù)據(jù)庫日志備份和恢復步驟
- SQL Server2008 數(shù)據(jù)庫誤刪除數(shù)據(jù)的恢復方法分享
- SQL server 2008 數(shù)據(jù)安全(備份和恢復數(shù)據(jù)庫)
- SQL Server誤區(qū)30日談 第20天 破壞日志備份鏈之后,需要一個完整備份來重新開始日志鏈
- Shell腳本定時備份清除運行系統(tǒng)日志的代碼
- win平臺oracle rman備份和刪除dg備庫歸檔日志腳本
- SQL Server 2008數(shù)據(jù)庫誤刪數(shù)據(jù)如何進行數(shù)據(jù)恢復
- SQL Server 2008及更高版本數(shù)據(jù)庫恢復方法之日志尾部備份
相關文章
mysql觸發(fā)器實現(xiàn)oracle物化視圖示例代碼
mysql觸發(fā)器實現(xiàn)oracle物化視圖即不是基于基表的虛表,而是根據(jù)表實際存在的實表,需要的朋友可以參考下2014-02-02MySQL里的found_row()與row_count()的解釋及用法
MySQL中有兩個函數(shù)來計算上一條語句影響了多少行,不同于SqlServer/Oracle,不要因為此方面的差異而引起功能問題2013-02-02MySQL5.7升級MySQL8.0的完整卸載與安裝及連接Navicat的步驟
因為一個項目交接需要需要將mysql物理備份文件還原至MySQL5.7,并且將mysql5.7升級到MySQL8.0,下面這篇文章主要給大家介紹了關于MySQL5.7升級MySQL8.0的完整卸載與安裝及連接Navicat的相關資料,需要的朋友可以參考下2023-03-03