以下的文章主要講述的是在AIX上對DB2數據庫進行備份的實際操作步驟, 以及對其在實際操作中值得我們大家留意的注意點的描述,以下就是文章對其操作步驟的詳細描述,望大家浏覽之後會對其有更好的了解。
AIX, DB2, 備份AIX, 數據庫
DB2數據庫離線和在線全備、增量備份及恢復的具體操作步驟:
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數據庫配置參數:
- 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狀態,要求做DB2數據庫的離線全備份。
做一下離線全備份,參考上面的命令。
(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)、這時DB2數據庫處於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 即可。表空間級別的備份/恢復操作要求DB2數據庫處於歸檔日志和啟用增量備份模式下。
(3)、恢復的例子中只做了版本恢復。若還有更新的全備份和增量備份的image,可以依次做恢復(請注意使用db2ckrst的建議恢復次序和次數)之後,最後做roll forward.