本文將為您介紹DB2數據庫離線和在線全備、增量備份及恢復的相關操作步驟,供您參考。DB2提供了高層次的數據利用性、完整性、安全性、可恢復性,以及小規模到大規模應用程序的執行能力,同時具有與平台無關的基本功能和SQL命令。
1、離線全備份
(1)、首先確保沒有用戶使用DB2:
$db2 list applications for db sample
(2)、停掉數據庫並重新啟動,以便斷掉所有連接:
db2stop force
db2start
(3)、執行備份命令:(使用TSM作為備份的介質)
db2 backup db sample use tsm
備份成功,將會返回一個時間戳。
(4)、檢查備份成功:
Db2 list history backup all for sample ,可以看到多了這個備份的紀錄。
Db2adutl query命令也可以看到返回值。
(5)、備注:
首先對主節點(catalog表空間在的節點)執行備份命令,再對另外的節點也做這個操作。
2、在線備份:
(1)、首先打開一下支持在線備份的數據庫配置參數:
db2 update db cfg for sample using userexit on 啟用用戶出口
db2 update db cfg for sample using logretain on 啟用歸檔日志
db2 update db cfg for sample using trackmod on 啟用增量備份功能
(需要各個Node都分別做設置)
開啟這些參數後,數據庫處於backup pending狀態,要求做數據庫的離線全備份。做一下離線全備份,參考上面的命令。
(2)、在線備份命令如下:
db2 backup db sample online use tsm
備份成功,返回一個時間戳。
(3)、同樣可以用db2adutl 和db2 list history察看備份紀錄。
(4)、備注:
同樣,對每個節點都做這個操作。
3、 在線增量備份
(1)、在開啟了必須的三個參數的情況下,做增量備份:
db2 backup db sample online incremental use tsm
備份成功,返回一個時間戳。
(2)、同樣可以用db2adutl 和db2 list history察看備份紀錄。
(3)、還有一種delta的備份:
db2 backup db sample online
incremental delta use tsm
這兩種備份的區別,類似Oracle Exports的Incremental和Cumulative方式,db2的incremental對應oracle的cumulative方式,而db2的delta方式則對應Oracle的incremental方式。
(4)、備注:同樣,對每個節點都做這個操作。
4、 恢復數據庫
(1)、手工drop數據庫,模擬災難恢復的情況,執行如下操作:
db2 drop db sample
(2)、恢復備份歷史紀錄(每次backup,不論類型,都會備份歷史紀錄文件)。這裡的時間戳應該是最新的:
db2 restore db sample history file use tsm
taken at 20030102223107 buffer 100
(3)、使用db2的恢復幫助工具:
db2ckrst -d sample -t 20030101224424 -r database
命令返回建議的必需的恢復操作命令。
(4)、按照幫助工具的提示,先做版本恢復,恢復命令如下:
db2 restore db sample incremental use tsm taken at 20030101224424 buffer 100
同樣先做主節點的恢復,再做其他節點的恢復操作。
(5)、這時數據庫處於rollforward-pending state的狀態,需要做roll forward 操作:
db2 rollforward db sample to 2003-01-12-13.27.25.000000 on all nodes and stop
前滾到同一個時間點。這個操作要在主節點來做。
5、說明:
(1)、恢復操作也有online和offline的,區別等同backup的操作。
(2)、按照表空間的備份和恢復類似,加子句TABLESPACE ( tablespace-name 即可。表空間級別的備份/恢復操作要求數據庫處於歸檔日志和啟用增量備份模式下。
(3)、恢復的例子中只做了版本恢復。若還有更新的全備份和增量備份的image,可以依次做恢復(請注意使用db2ckrst的建議恢復次序和次數)之後,最後做roll forward.