使用LOAD工具導(dǎo)致DB2進(jìn)入備份暫掛、復(fù)原暫掛、裝入暫掛及完整性暫掛問題的解決方法

為了加快數(shù)據(jù)的裝載速度,許多DBA們喜歡使用load工具進(jìn)行數(shù)據(jù)的遷移和裝載,但是load工具帶來便利性的同時(shí)也為我們帶來一些問題,今天就著重介紹一下當(dāng)我們?cè)偈褂肔oad工具時(shí)遇到問題后的解決辦法。

眾所周知,load過程分為4個(gè)階段:load/build/delete/index copy。load階段是將源文件parser成物理數(shù)據(jù)存儲(chǔ)的格式,直接裝入到頁(yè)中,而不通過db2引擎,load階段會(huì)檢查表定義,違背定義的數(shù)據(jù)不會(huì)裝入到表中。build階段建議索引(如果裝入表有索引的話),會(huì)檢查唯一性約束,違背了唯一性的數(shù)據(jù)會(huì)在delete階段刪除。index copy階段將index數(shù)據(jù)從指定的臨時(shí)表空間拷貝到初始的表空間里,index copy只適應(yīng)于allow read access場(chǎng)景。load的4個(gè)階段會(huì)記錄在messages文件里。而db2 load如果不加nonrecoverable可能導(dǎo)致table space變?yōu)閎ackup pending等狀態(tài)。

本文主要介紹 DB2 LOAD 命令所提供的 COPY NO/COPY YES/NONRECOVERABLE 選項(xiàng),以及與之相關(guān)的注冊(cè)表變量的使用方法等。?

由于 LOAD 最小化了日志的記錄,因啟用了前滾恢復(fù)的數(shù)據(jù)庫(kù)在恢復(fù)在線備份時(shí)需要?dú)w檔日志的特性,對(duì)于這種數(shù)據(jù)庫(kù)的 LOAD 操作,為避免執(zhí)行 LOAD 操作后,表在使用 ROLLFORWARD 命令前滾歸檔日志的過程中因缺少日志而被置為非正常狀態(tài),DB2 為 LOAD 命令提供了如下選項(xiàng):?

·COPY NO(缺?。?

·COPY YES?

·NONREVERABLE?

1. 進(jìn)行一次數(shù)據(jù)庫(kù)的全備份:?

首先對(duì)已啟用前滾恢復(fù)模式的 SAMPLE 數(shù)據(jù)庫(kù)進(jìn)行一次全備份:?

E:\TEST>db2 backup db sample?

備份成功。此備份映像的時(shí)間戳記是:20051230174105?

這時(shí)看到在當(dāng)前目錄下產(chǎn)生了一個(gè) SAMPLE.0 的子目錄,表明產(chǎn)生的是一個(gè)數(shù)據(jù)庫(kù)全備份。下面將對(duì)這些現(xiàn)象逐個(gè)予以舉例說明:?

2. 關(guān)于 COPY NO的備份暫掛:?

在 LOAD 操作結(jié)束時(shí),將表所在的表空間置于“備份暫掛”狀態(tài),此時(shí)雖然其中的表可以進(jìn)行 SELECT 操作,但不能進(jìn)行 UPDATE 和 DELETE 操作。為使該表狀態(tài)恢復(fù)正常,除去備份暫掛狀態(tài),必須手動(dòng)對(duì)其表空間執(zhí)行一個(gè) BACKUP 命令。由于該選項(xiàng)為缺省選項(xiàng),如果 LOAD 命令中未指明,則默認(rèn)為使用該選項(xiàng),如:?

E:\TEST>db2 connect to sample?

E:\TEST>db2 load from staff.del of del insert into staff?

E:\TEST>db2 list tablespaces?

表空間標(biāo)識(shí) = 2?

名稱 = USERSPACE1?

類型 = 系統(tǒng)管理空間?

內(nèi)容 = 任何數(shù)據(jù)?

狀態(tài) = 0x0020?

詳細(xì)解釋:?

備份暫掛:

E:\TEST>db2 select count(*) from staff?

1?

-----------?

70?

1 條記錄已選擇。?

E:\TEST>db2 update staff set id=335 where id=340?

DB21034E 該命令被當(dāng)作 SQL 語句來處理,因?yàn)樗皇怯行У摹懊钚刑幚砥鳌泵?。?SQL 處理期間,它返回:?

SQL0290N 不允許存取表空間。 SQLSTATE=55039?

在手動(dòng)對(duì) USERSPACE1 表空間進(jìn)行一次備份操作后,表空間狀態(tài)將正常,再次嘗試更新操作就會(huì)成功:?

E:\TEST>db2 backup db sample tablespace (userspace1)?

備份成功。此備份映像的時(shí)間戳記是:20051230184841?

命令完成后可以在當(dāng)前目錄下看到產(chǎn)生了一個(gè) SAMPLE.3 的子目錄,表明產(chǎn)生的是一個(gè)表空間級(jí)的備份。?

E:\TEST>db2 connect to sample?

E:\TEST>db2 list tablespaces?

表空間標(biāo)識(shí) = 2?

名稱 = USERSPACE1?

類型 = 系統(tǒng)管理空間?

內(nèi)容 = 任何數(shù)據(jù)?

狀態(tài) = 0x0000?

詳細(xì)解釋:?

正常?

3. 關(guān)于 COPY NO的復(fù)原暫掛:?

而所產(chǎn)生這份關(guān)于表空間的備份可在數(shù)據(jù)庫(kù)因前滾操作將表空間置為“復(fù)原暫掛”狀態(tài)時(shí)用于將表空間狀態(tài)恢復(fù)為正常,并恢復(fù) LOAD 操作對(duì)該表的修改。如當(dāng)前滾數(shù)據(jù)庫(kù)超過LOAD時(shí)間點(diǎn)后,表空間將被置為復(fù)原暫掛狀態(tài):?

E:\TEST>db2 restore db sample taken at 20051230174105?

DB20000I RESTORE DATABASE 命令成功完成。

E:\TEST>db2 rollforward db sample to end of logs and stop?

SQL1271W 已恢復(fù)數(shù)據(jù)庫(kù) "SAMPLE",但在節(jié)點(diǎn) "0"上有一個(gè)或多個(gè)表空間脫機(jī)?

E:\TEST>db2 connect to sample?

E:\TEST>db2 list tablespaces?

表空間標(biāo)識(shí) = 2?

名稱 = USERSPACE1?

類型 = 系統(tǒng)管理空間?

內(nèi)容 = 任何數(shù)據(jù)?

狀態(tài) = 0x0100?

詳細(xì)解釋:?

復(fù)原暫掛?

此時(shí)可利用這一表空間級(jí)的備份進(jìn)行恢復(fù)操作:?

E:\TEST>db2 restore db sample tablespace (userspace1) taken at 20051230184841?

DB20000I RESTORE DATABASE 命令成功完成。?

E:\TEST>db2 connect to sample?

E:\TEST>db2 list tablespaces ?

表空間標(biāo)識(shí) = 2?

名稱 = USERSPACE1?

類型 = 系統(tǒng)管理空間?

內(nèi)容 = 任何數(shù)據(jù)?

狀態(tài) = 0x0080?

詳細(xì)解釋:?

前滾暫掛:

E:\TEST>db2 rollforward db sample to end of logs and stop tablespace (userspace1)?

前滾狀態(tài)?

輸入數(shù)據(jù)庫(kù)別名 = sample?

節(jié)點(diǎn)數(shù)已返回狀態(tài) = 1?

節(jié)點(diǎn)號(hào) = 0?

前滾狀態(tài) = 未暫掛?

下一個(gè)要讀取的日志文件 =?

已處理的日志文件 = -?

上次落實(shí)的事務(wù) = 2005-12-30-10.47.10.000000?

DB20000I ROLLFORWARD 命令成功完成。?

E:\TEST>db2 connect to sample?

E:\TEST>db2 list tablespaces?

表空間標(biāo)識(shí) = 2?

名稱 = USERSPACE1?

類型 = 系統(tǒng)管理空間?

內(nèi)容 = 任何數(shù)據(jù)?

狀態(tài) = 0x0000?

詳細(xì)解釋:?

正常?

E:\TEST>db2 update staff set id=335 where id=340?

DB20000I SQL 命令成功完成。?

可見表空間狀態(tài)已正常,表也可執(zhí)行更新操作了。?

4. 關(guān)于 COPY YES:?

在 LOAD 操作結(jié)束時(shí),DB2 自動(dòng)對(duì)表所在的表空間進(jìn)行一次備份操作,因而 LOAD 結(jié)束后,表所在的表空間不會(huì)再處于“備份暫掛”狀態(tài),而為“正?!睜顟B(tài)。但由于要進(jìn)行備份操作,所以這種 LOAD 操作的時(shí)間會(huì)較沒有備份的長(zhǎng)。如:?

E:\TEST>db2 connect to sample?

E:\TEST>db2 load from staff.del of del insert into staff copy yes to .?

E:\TEST>db2 list tablespaces

表空間標(biāo)識(shí) = 2?

名稱 = USERSPACE1?

類型 = 系統(tǒng)管理空間?

內(nèi)容 = 任何數(shù)據(jù)?

狀態(tài) = 0x0000?

詳細(xì)解釋:?

正常?

E:\TEST>db2 select count(*) from staff?

1?

-----------?

105?

1 條記錄已選擇。?

此時(shí)可在當(dāng)前目錄下看到一個(gè) SAMPLE.4 的子目錄,表明產(chǎn)生的是一個(gè)由 LOAD 操作生成的備份,而這份備份將在數(shù)據(jù)庫(kù)進(jìn)行前滾恢復(fù)操作時(shí)用于重新創(chuàng)建 LOAD 操作對(duì)數(shù)據(jù)庫(kù)的修改。如:?

E:\TEST>db2 restore db sample taken at 20051230174105?

DB20000I RESTORE DATABASE 命令成功完成。?

E:\TEST>db2 rollforward db sample to end of logs and stop?

前滾狀態(tài)?

輸入數(shù)據(jù)庫(kù)別名 = sample?

節(jié)點(diǎn)數(shù)已返回狀態(tài) = 1?

節(jié)點(diǎn)號(hào) = 0?

前滾狀態(tài) = 未暫掛?

下一個(gè)要讀取的日志文件 =?

已處理的日志文件 = S0000002.LOG - S0000003.LOG?

上次落實(shí)的事務(wù) = 2005-12-30-11.48.26.000000?

DB20000I ROLLFORWARD 命令成功完成。?

E:\TEST>db2 connect to sample?

E:\TEST>db2 list tablespaces?

表空間標(biāo)識(shí) = 2?

名稱 = USERSPACE1?

類型 = 系統(tǒng)管理空間?

內(nèi)容 = 任何數(shù)據(jù)?

狀態(tài) = 0x0000?

詳細(xì)解釋:?

正常?

E:\TEST>db2 select count(*) from staff?

1?

-----------?

105?

1 條記錄已選擇。?

這表明在 SAMPLE.4 下的備份被用于了前滾恢復(fù)操作,而重新創(chuàng)建了 LOAD 操作對(duì)數(shù)據(jù)庫(kù)插入的記錄。?

5. 關(guān)于 NONRECOVERABLE:?

該選項(xiàng)會(huì)將 LOAD 操作標(biāo)志為不可恢復(fù),即數(shù)據(jù)庫(kù)不能通過后續(xù)的前滾操作而被恢復(fù)。LOAD 操作結(jié)束后,數(shù)據(jù)庫(kù)既不會(huì)處于“備份暫掛”狀態(tài),也不會(huì)產(chǎn)生任何的備份。?

E:\TEST>db2 connect to sample?

E:\TEST>db2 load from staff.del of del insert into staff nonrecoverable?

E:\TEST>db2 list tablespaces?

表空間標(biāo)識(shí) = 2?

名稱 = USERSPACE1?

類型 = 系統(tǒng)管理空間?

內(nèi)容 = 任何數(shù)據(jù)?

狀態(tài) = 0x0000?

詳細(xì)解釋:?

正常?

雖然 LOAD 之后表空間和表的狀態(tài)都正常,但如果今后需要執(zhí)行前滾命令恢復(fù)數(shù)據(jù)庫(kù)時(shí),前滾操作將跳過 LOAD 事務(wù)的處理,而將 LOAD 的表標(biāo)記為無效,是對(duì)表的任何操作都不能進(jìn)行。如:?

E:\TEST>db2 restore db sample taken at 20051230174105?

DB20000I RESTORE DATABASE 命令成功完成。?

E:\TEST>db2 rollforward db sample to end of logs and stop?

前滾狀態(tài)?

輸入數(shù)據(jù)庫(kù)別名 = sample?

節(jié)點(diǎn)數(shù)已返回狀態(tài) = 1?

節(jié)點(diǎn)號(hào) = 0?

前滾狀態(tài) = 未暫掛?

下一個(gè)要讀取的日志文件 =?

已處理的日志文件 = S0000002.LOG - S0000003.LOG?

上次落實(shí)的事務(wù) = 2005-12-30-12.19.55.000000?

DB20000I ROLLFORWARD 命令成功完成。?

E:\>db2 connect to sample?

E:\TEST>db2 list tablespaces?

表空間標(biāo)識(shí) = 2?

名稱 = USERSPACE1?

類型 = 系統(tǒng)管理空間?

內(nèi)容 = 任何數(shù)據(jù)?

狀態(tài) = 0x0000?

詳細(xì)解釋:?

正常?

E:\>db2 select * from staff?

ID NAME DEPT JOB YEARS SALARY COMM?

------ --------- ------ ----- ------ --------- ---------?

SQL1477N 不能存取表 "LIWENLI.STAFF"。 SQLSTATE=55019?

這表明該表已不可操作,此時(shí)只有將表刪除,重新構(gòu)建,或使用 LOAD 操作時(shí)間點(diǎn)之后所做的數(shù)據(jù)庫(kù)全備份或表空間備份來恢復(fù)該表。?

5. 關(guān)于注冊(cè)表變量 DB2_LOAD_COPY_NO_OVERRIDE 的介紹:?

另外 DB2 還提供了一個(gè)注冊(cè)表變量:DB2_LOAD_COPY_NO_OVERRIDE,可將 LOAD 的缺省選項(xiàng) COPY NO 設(shè)置為 NONRECOVERABLE 或 COPY YES。具體使用方法舉例為:?

設(shè)置為 COPY YES 的方法:?

E:\TEST>db2set DB2_LOAD_COPY_NO_OVERRIDE="COPY YES TO E:\TEST"?

E:\TEST>db2 terminate?

E:\TEST>db2set?

DB2_LOAD_COPY_NO_OVERRIDE=COPY YES TO E:\TEST?

E:\TEST>db2 load from staff.del of del insert into staff?

SQL27966W DB2_LOAD_COPY_NO_OVERRIDE 注冊(cè)表變量值 "COPY YES TO E:\TEST" 將覆蓋在 Load 中指定的 COPY NO 參數(shù)。?

設(shè)置為 NONRECOVERABLE 的方法:?

E:\TEST>db2set DB2_LOAD_COPY_NO_OVERRIDE=NONRECOVERABLE?

E:\TEST>db2 terminate?

E:\TEST>db2set?

DB2_LOAD_COPY_NO_OVERRIDE=NONRECOVERABLE?

E:\TEST>db2 load from staff.del of del insert into staff?

SQL27966W DB2_LOAD_COPY_NO_OVERRIDE 注冊(cè)表變量值 "NONRECOVERABLE" 將覆蓋在Load 中指定的 COPY NO 參數(shù)。?

通過上述對(duì) LOAD 的 COPY NO,COPY YES 和 NONRECOVERABLE 參數(shù),以及 DB2 注冊(cè)表變量 DB2_LOAD_COPY_NO_OVERRIDE 的詳細(xì)和舉例說明,到此我們已經(jīng)掌握了它們的功能和使用方法。由于 LOAD 操作幾乎不記日志的特性,在對(duì)啟用了前滾恢復(fù)的數(shù)據(jù)庫(kù)實(shí)現(xiàn) LOAD 操作時(shí)應(yīng)注意從中選擇適當(dāng)?shù)倪x項(xiàng),以保證執(zhí)行了 LOAD 操作的表的可用性.

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容