chapter9:執行備份和恢復
2024-07-21 02:07:52
供稿:網友
第 9 章:執行備份和恢復 目的
本章向您介紹通過 enterprise manager 執行的 oracle database 備份和恢復操作。
主題
本章討論了以下內容:
配置閃回恢復區和 archivelog 模式 配置備份設置和策略 定義 dbid 和 db_unique_name 的值 執行完整的數據庫備份 利用 oracle 建議的備份策略對數據庫進行備份 還原和恢復整個數據庫 執行閃回表 執行閃回丟棄 管理備份 查看屏幕截圖
將鼠標移到這個圖標上,顯示所有的屏幕截圖。您還可以將鼠標移到各個圖標上,只查看與該圖標相關的屏幕截圖。
配置閃回恢復區和 archivelog 模式
返回主題列表
閃回恢復區是為 oracle 數據庫中的所有與恢復相關的文件和活動提供的一個統一的存儲位置。將數據庫從介質故障中完全恢復過來所需的全部文件都屬于閃回恢復區??梢栽陂W回恢復區中創建的與恢復相關的文件包括:存檔重做日志文件、控制文件、由恢復管理器 (rman) 創建的備份、閃回日志和修改跟蹤文件。oracle 推薦在與數據庫文件所在相同的磁盤上創建修改跟蹤文件。實際上,如果您安裝了 omf,并執行了啟用修改跟蹤的命令,那么將自動在為數據庫文件指定的目錄中創建跟蹤文件。
通過分配一個存儲位置并將相關的恢復文件統一在一個特定的區域內,oracle 數據庫服務器使數據庫管理員不必再管理由這些組件創建的磁盤文件。
當創建閃回恢復區時,您可以選擇一個目錄、文件系統或自動存儲管理磁盤組來存放文件,并為閃回恢復區中用于存儲所有文件的最大空間設置一個磁盤限額。您必須選擇一個足夠大的區域,以容納所需的磁盤限額。當接近磁盤空間界限時,oracle 服務器可以根據 rman 保留策略的界限來刪除非必要的文件,為新文件騰出空間。
閃回恢復區應該在一個與工作區分離的磁盤上,其中存儲著在增量備份中使用的活動數據庫文件(如數據文件、控制文件、在線重做日志和修改跟蹤文件)。將閃回恢復區和工作區置于相同的磁盤上,當出現磁盤故障時,很容易使您同時丟失活動的數據庫文件以及備份。
當您創建數據庫時,可以配置閃回恢復區和 archivelog 模式。如果您在您創建數據庫時沒有執行這些任務,那么請按照以下步驟來配置閃回恢復區和 archivelog 模式:
1.
在操作系統提示符下為閃回恢復區創建一個目錄。執行下列命令:
cd $oracle_base mkdir flash_rec_area
2.
打開瀏覽器,并指定用戶名為 sys,口令為 sysdba,以登錄 enterprise manager database console。單擊 login。
3.
單擊 oracle database home 頁面上的 maintenance。
4.
在 backup/recovery 部分中選擇 configure recovery settings。您可以使用 configure recovery settings 頁面來配置恢復實用工具的設置,包括閃回恢復區。
5.
出現 configure recovery settings 頁面。滾動至 flash recovery area 部分。在相應字段中輸入下列值來配置閃回恢復區:
flash recovery area location:<在第 1 步中創建的目錄步中創建的目錄閃回恢復區所需的大小pgy0<>flash recovery area size:<閃回恢復區所需的大小>
向上滾動至窗口頂部。
6.
選中 archive log mode,為數據庫配置 archivelog 模式。單擊 apply。
7.
顯示一條確認修改的消息。要完成 archivelog 模式的配置,必須關閉數據庫例程。單擊 yes,關閉例程并重新啟動它。
8.
顯示 restart database:specify host and target database credentials 頁面。輸入主機證書和數據庫證書。單擊 ok。
9.
顯示 restart database:confirmation 頁面。單擊 yes,關閉例程并重新啟動它。
10.
顯示 restart database:activity information 頁面。單擊 refresh,登錄 enterprise manager database control。
配置備份設置和策略
返回主題列表
您可以配置許多設置和策略來確定如何存儲備份、備份哪些數據、如何執行備份,以及備份在從恢復區中清除之前保留多久。您還可以配置特性來提高備份性能。
1.
單擊 oracle database 主頁上的 maintenance 頁面。
2.
在 backup/recovery 區域中選擇 configure backup settings。
3.
滾動至 configure backup settings 頁面的 host credentials 區域。輸入操作系統用戶名和口令。向上滾動至 disk settings 部分。
4.
接受 device 頁面上的 disk settings 部分中的 parallelism 字段中的值 1。設置 disk backup location 字段為 null,以使用閃回恢復區進行備份。對 disk backup type 選擇 backup set。單擊 test disk backup。
5.
顯示一條消息,指示磁盤設置備份測試成功完成。現在您將配置備份策略設置。單擊 policy,訪問 policy 頁面。
6.
選擇 automatically backup the control file and server parameter file (spfile) with every backup and database structural change。選擇 optimize the whole database backup by skipping unchanged files such as read-only and offline datafiles that have been backed up。選擇 enable block change tracking for faster incremental backups。為 block change tracking file 輸入一個文件名。然后向下滾動到 retention policy 部分。
7.
選擇 retain backups that are necessary for a recovery to any time within the specified number of days (point-in-time recovery),并接受默認值(31 天)。單擊 ok。返回到 maintenance 頁面。
確定 dbid 和 db_unique_name 的值
返回主題列表
如果您丟失了數據庫控制文件或 spfile,enterprise manager 可以從備份中恢復它們 — 只要您能夠為數據庫提供 db_unique_name 和 dbid。
執行以下步驟,確定 db_unique_name 的值:
1.
單擊 administration 頁面上的 instance 區域中的 all initialization parameters。
2.
出現 current 屬性頁面。在 filter 字段中輸入 db_unique_name,然后單擊 go。
3.
出現的頁面顯示了一行,該行的 name 列為 db_unique_name,value 列中給出了數據庫的db_unique_name 的值。
記錄這個值,以便將來您需要它來進行恢復操作時,可以獲得它。
執行以下步驟來確定 dbid:
1.
單擊 administration 頁面的 storage 區域中的 controlfiles。
2.
出現 controlfiles 屬性頁面。選擇 advanced 屬性頁面。
3.
database id 字段包含 dbid 值。
記錄這個值,以便將來您需要它來進行恢復操作時,可以獲得它。
執行完整的數據庫備份
返回主題列表
您可以通過執行一次完整的數據庫備份來備份數據庫的全部內容。所有數據文件的完整備份都將被創建。結果可能作為鏡像拷貝或作為備份集存儲,但在任意情況下,數據庫的所有數據文件以及控制文件、存檔重做日志和服務器參數文件的全部內容都將在備份中反映出來。利用這個文件集,可以完整的恢復數據庫。
1.
在 backup/recovery 區域中選擇 schedule backup。
2.
出現 schedule backup:strategy 頁面。從 backup strategy 下拉菜單中選擇 customized。選擇 whole database,如果需要,在 host credentials 部分中輸入用戶名和口令。單擊 next。
3.
出現 schedule backup:options 頁面。在 backup type 部分中選擇 full backup。在 backup mode 部分中選擇 online backup。在 advanced 部分中選中 back up all archived logs on disk。單擊 next。
4.
出現 schedule backup:settings 頁面。適當地選擇 disk 或 tape。單擊 next。
5.
出現 schedule backup:schedule 頁面。接受默認的作業名稱。選擇 immediately,立即執行作業,或輸入在稍后執行的時間。單擊 next。
6.
出現 schedule backup:review 頁面。單擊 submit job。
7.
顯示 backup submit successful 消息。單擊 ok。
利用 oracle 建議的備份策略對數據庫進行備份
返回主題列表
oracle 建議的備份策略的基礎是創建數據庫的一個鏡像拷貝,然后利用 rman 增量備份繼續生成備份。oracle enterprise manager 調度 rman 備份作業。按照以下步驟來設置備份計劃:
1.
在 backup/recovery 區域中選擇 schedule backup。
2.
出現 schedule backup:strategy 頁面。從 backup stratgy 下拉菜單中選擇 oracle-suggested。在 "select your backup destination" 下選擇 disk。在 host credentials 部分中輸入操作系統用戶名和口令。單擊 next。
3.
出現 schedule backup:setup 頁面。請仔細查看信息,然后單擊 next。
4.
出現 schedule backup:schedule 頁面。仔細查看信息,并相應地調整開始日期和時間。單擊 next。
5.
出現 schedule backup:review 頁面。請仔細查看信息,然后單擊 submit job。
6.
出現 status 頁面和一條指示作業成功提交的消息。您可以單擊 view job 來訪問作業狀態頁面或單擊 ok 來完成操作。
還原和恢復整個數據庫
返回主題列表
在這一部分中,您將通過 enterprise manager 來恢復數據文件。
1.
在 backup/recovery 區域中選擇 perform recovery。
2.
出現 perform recovery:type 頁面。從 type 部分中的 object type 下拉菜單中選擇 whole database。選擇 recover to the current time or a previous point-in-time 作為 operation type。在 host credentials 部分中輸入操作系統用戶名和口令。單擊 next。
4.
顯示 recovery wizard 頁面,指示例程將關閉并重啟。單擊 refresh,繼續使用 recovery wizard。
5.
單擊 perform recovery,恢復數據庫。
6.
在 host credentials 區域中輸入操作系統用戶名和口令。在 database credentials 區域中輸入 sys 和 sys 的口令。單擊 continue。
7.
再次出現 perform recovery:type 頁面。數據庫現在處于加載狀態。單擊 next。
8.
出現 perform recovery:point-in-time 頁面。選擇 recover to the current time。單擊 next。
9.
出現 perform recovery:rename 頁面。選擇 no. restore the files to the default location(如果您希望這樣)或者選擇 yes.restore the files to a new, common location,并輸入位置。單擊 next。
10.
出現 perform recovery:review 頁面。仔細查看信息,然后單擊 submit。
11.
收到 "operation succeeded" 消息。單擊 ok。
執行閃回表
返回主題列表
完成以下任務來執行閃回表操作:
啟用行轉移 模擬用戶錯誤 執行閃回表 啟用行轉移
返回列表
您必須在表上啟用行轉移,以在表上執行閃回表操作。在這一部分中,您將在 hr.employees 表上啟用行轉移。
1.
在 oracle database home 頁面上單擊 administration。
2.
出現 administration 屬性頁面。在 schema 部分中選擇 tables。
3.
出現 tables 頁面。從 object type 下拉菜單中選擇 table。在 schema 字段中輸入 hr,在 object name 字段中輸入 regions。單擊 go。
4.
regions 表顯示在 results 部分中。單擊 edit。
5.
出現 edit table 頁面。單擊 options 標簽。
6.
從 enable row movement 下拉菜單中選擇 yes。單擊 apply。
7.
收到一條消息,指示表成功修改。選擇路徑式導航欄中的 tables 導航項。
模擬用戶錯誤
返回列表
在這一部分中,您將通過修改 regions 表中的數據來模擬用戶錯誤。執行以下操作:
1.
通過打開一個終端窗口和執行以下命令來查看 regions 表中的數據:
sqlplus hr/hr col region_name format a30 select * from regions;
2.
通過執行以下 sql 命令來修改所有行中的 region_name 列中的值,以模擬用戶錯誤:
update regions set region_name = 'oracle'; commit;
3.
再次執行以下命令來查看修改:
select * from regions;
在執行閃回表部分中,您將把表閃回到您更新表之前的時間點上。
執行閃回表
返回列表
在這一部分中,您將閃回 hr.regions 表。
1.
驗證在表的列表中仍然選中了 regions。從 actions 下拉菜單中選擇 flashback table。單擊 go。
2.
出現 perform recovery:point-in-time 頁面。選擇 flashback to a timestamp,然后輸入幾分鐘以前的一個日期和時間。單擊 next。
3.
出現 perform recovery:flashback tables 頁面。仔細查看頁面上的信息,然后單擊 next。
4.
出現 perform recovery:review 頁面。仔細查看信息,然后單擊 submit。
5.
接收到一條消息,確認表已被閃回。單擊 ok。
6.
切換回 sql*plus 會話,執行以下命令來驗證閃回表操作:
select * from regions;
執行閃回丟棄
返回主題列表
在這一部分中,您將使用閃回丟棄特性來取回被丟棄的表。為了完成本練習,您將創建一個新的表、丟棄該表,然后用閃回丟棄來恢復它。
按照下列步驟來創建一個新的表,然后丟棄它:
1.
在 schema name 字段中輸入 hr,并在 object name 字段中輸入 regions 或 regions 的一部分,然后單擊 go。
2.
從 action 下拉菜單中選擇 create like。單擊 go。
3.
出現 create table 頁面。在 name 字段中輸入 reg_hist。取消 region_id 列選定的 not null。單擊 constraints。
4.
出現 constraints 頁面。選中每一個約束條件,然后單擊 delete 來刪除表上的約束條件。本練習不需要這些約束條件。
5.
單擊 ok,創建 reg_hist 表。
6.
收到一條消息,指示表已創建。在 object name 字段中輸入 reg_hist,然后單擊 go。
7.
顯示 tables 頁面,并在 results 部分中顯示 reg_hist 表。單擊 delete 來刪除 reg_hist 表。
8.
單擊 yes,確認刪除表。
9.
顯示一條消息,指示表已刪除。單擊 go,嘗試取回表。
10.
在結果部分中顯示 no object found。
要恢復您剛剛刪除的表,您將需要執行一次閃回丟棄。執行以下操作:
1.
單擊 recycle bin。
2.
在 schema name 字段中輸入 hr,然后單擊 go。
3.
驗證選中了 reg_hist,然后單擊 flashback drop。
4.
出現 perform recovery: rename 頁面。單擊 next。
5.
出現 perform recovery:review 頁面。仔細查看信息,然后單擊 submit。
6.
顯示一條確認消息。單擊 ok。
7.
回收站中不再有該表。單擊路徑式導航欄中的 tables 導般項。
8.
reg_hist 表現在被包含在表的列表中。
管理備份
返回主題列表
管理備份包括兩個任務:管理存在于磁盤或磁帶上的備份自身,和管理保存在 rman 信息庫中的備份記錄。在這一部分中,您將執行備份維護和更新 rman 信息庫。在這一部分中,您將執行以下任務:
使用 manage current backups 頁面 交叉查對備份 刪除過期備份 刪除廢棄備份 標記備份為 unavailable 編制備份的目錄
使用 manage current backups 頁面
返回主題列表
您可以使用 manage current backups 頁面來查看在 rman 信息庫中記錄的備份。從這個頁面中,您可以執行在這整個部分中說明的備份維護操作。
1.
單擊 maintenance 屬性頁面的 backup/recovery 區域中的 manage current backups。
2.
顯示 manage current backups 頁面。backup sets 屬性頁面顯示在 rman 信息庫中記錄的備份集。單擊 contents 列中的鏈接來查看關于一個備份集的內容的詳細信息。
3.
顯示 contents 屬性頁面。單擊 manage current backups,返回 manage current backups 屬性頁面。
4.
單擊 image copies,查看 image copies 頁面。
5.
顯示 image copies 頁面,該頁面顯示記錄在 rman 信息庫中的鏡像拷貝。
交叉查對備份
返回主題列表
當您交叉查對一個備份時,rman 驗證記錄在信息庫中的信息與實際備份狀態是否保持一致。如果不一致,則將更新信息庫來反映正確的狀態。您可以按以下方式來交叉查對所有的備份文件:
1.
單擊 maintenance 屬性頁面的 backup/recovery 區域中的 manage current backups。
2.
顯示 manage current backups 頁面。單擊頁面頂部的 crosscheck all 來交叉查對 rman 信息庫中的所有文件。
3.
顯示 crosscheck all:specify job parameters 頁面。您可以接受 job name、job description、start time 和 repeat 規范的默認值,或輸入自己的值。單擊 submit job,提交交叉查對作業。
4.
在 manage current backups 頁面上顯示了一條 job submission succeeded 消息。您可以單擊 view job 來查看作業的狀態。
5.
在 summary 區域中,您可以查看作業的狀態。
刪除過期備份
返回主題列表
您可以通過執行以下步驟來刪除 rman 信息庫中標記為 expired 的所有備份:
1.
單擊 maintenance 屬性頁面的 backup/recovery 區域中的 manage current backups。
2.
顯示 manage current backups 頁面。單擊頁面頂部的 delete all expired,從 rman 信息庫中刪除標記為 expired 的那些備份。
3.
顯示 delete all expired:specify job parameters 頁面。您可以接受 job name、job description、start time 和 repeat 規范的默認值,或輸入自己的值。如果您沒有執行交叉查對操作,選擇 perform the operation 'crosscheck all' before 'delete all expired'。 單擊 submit job,提交作業。
4.
在 manage current backups 頁面上顯示了一條 job submission succeeded 消息。您可以單擊 view job 來查看作業的狀態。
5.
在 summary 區域中,您可以查看作業的狀態。
刪除廢棄備份
返回主題列表
您可以通過執行以下步驟來刪除所有廢棄的備份:
1.
單擊 maintenance 屬性頁面的 backup/recovery 區域中的 manage current backups。
2.
顯示 manage current backups 頁面。單擊頁面頂部的 delete all obsolete,從 rman 信息庫中刪除所有過時的備份。注意:您可以從 backup sets 或 image copies 頁面中執行這一操作。
3.
顯示 delete all obsolete:specify job parameters 頁面。您可以接受 job name、job description、start time 和 repeat 規范的默認值,或輸入自己的值。單擊 submit job,提交作業。
4.
在 manage current backups 頁面上顯示了一條 job submission succeeded 消息。您可以單擊 view job 來查看作業的狀態。
5.
在 summary 區域中,您可以查看作業的狀態。
6.
返回 image copies 和/或 backup sets 屬性頁面來驗證廢棄的備份是否已被刪除。
標記備份為 unavailable
返回主題列表
您可以通過執行以下步驟來把信息庫中的備份標記為 unavailable:
1.
單擊 maintenance 屬性頁面的 backup/recovery 區域中的 manage current backups。
2.
顯示 manage current backups 頁面。選擇您希望標記為 unavailable 的備份,并單擊 change to unavailable。
3.
顯示 confirmation 頁面。單擊 yes,繼續操作。
4.
顯示 request in process 頁面。
編制備份的目錄
返回主題列表
您可以為利用操作系統命令獲取的備份編制目錄,以便 rman 可以在恢復操作中使用它們。在本例中,您將使用操作系統命令來備份屬于 example 表空間的數據文件。然后您將使用 enterprise manager 來為 rman 信息庫中的備份文件編制目錄。
1.
調用 sql*plus,并作為一個擁有 sysdba 權限的用戶登錄。通過執行以下命令來使 example 表空間處于在線備份模式:
alter tablespace example begin backup;
2.
返回操作系統提示符,創建屬于 example 表空間的數據文件的一個拷貝。在本例中,拷貝創建在一個名稱為 backup 的目錄中。您可以使用您自己選擇的一個目錄。
3.
執行以下命令,使 example 表空間退出在線備份模式:
alter tablespace example end backup;
4.
現在您已經做好準備,可以利用 enterprise manager database control 來為 rman 信息庫中的備份編制目錄。單擊 maintenance 屬性頁面的 backup/recovery 區域中的 manage current backups。
5.
選擇 manage current backups 頁面頂部的 catalog additional files。
6.
選擇 catalog files in the specified disk location into the recovery manager repository,然后輸入位置和備份文件的名稱(無需文件擴展名)。單擊 ok。
7.
顯示 request in process 頁面。
8.
顯示一條確認消息,指示已完成文件的目錄編制。
將鼠標移到這個圖標上,以隱藏所有的屏幕截圖