使用12c物理Standby跨網路還原丟失檔案

hooca發表於2016-06-29
OS:Oracle Linux 6.6 x64
DB:Oracle 12.1.0.2

從12c開始,可以使用物理備庫中的物件,直接restore或recover主庫中對應的物件,包括database,tablespace,datafile,控制檔案、引數檔案。

所謂“直接”,表示備庫無需事先做backup,只要在主庫執行restore,將即刻在備庫自動建立備份,然後自動傳輸到主庫,最後自動在主庫還原恢復。

下例中,將模擬在主庫破壞一個表空間,並用備庫嘗試還原。

注:在執行通過網路restore&recover的操作前,參考文件MOS:ID 1987193.1,編輯sqlnet.ora

在主庫offline一個表空間,PDB1下的USERS表空間:

點選(此處)摺疊或開啟

  1. $ sqlplus system@pdb1
  2. SQL> alter tablespace users offline;
然後刪除ASM中的對應檔案:

點選(此處)摺疊或開啟

  1. ASMCMD> rm USERS.280.915735449
注意:之前之所以要offline表空間,是因為ASM會保護正在活動的資料檔案免於刪除,如果是檔案系統的話,就直接刪檔案吧,畢竟這裡就是要模擬主庫檔案丟失的場景。

到這裡,主庫的資料檔案發生了丟失,下面開始用備庫的檔案進行restore:

點選(此處)摺疊或開啟

  1. rman target /

  2. RMAN> restore tablespace pdb1:users from service stby;

  3. Starting restore at 2016-06-29 12:00:57
    using target database control file instead of recovery catalog
    allocated channel: ORA_DISK_1
    channel ORA_DISK_1: SID=258 instance=racdb1 device type=DISK


    channel ORA_DISK_1: starting datafile backup set restore
    channel ORA_DISK_1: using network backup set from service stby
    channel ORA_DISK_1: specifying datafile(s) to restore from backup set
    channel ORA_DISK_1: restoring datafile 00011 to +DATA/RACDB/36556EC6931E6245E0531506A8C09CF7/DATAFILE/users.280.915735449
    channel ORA_DISK_1: restore complete, elapsed time: 00:00:08
    Finished restore at 2016-06-29 12:01:08

接下來,由於本地保留了完整的日誌檔案,只需使用本地recover即可。

點選(此處)摺疊或開啟

  1. RMAN> recover tablespace pdb1:users;


  2. Starting recover at 2016-06-29 12:02:17
  3. using channel ORA_DISK_1

  4. starting media recovery
  5. media recovery complete, elapsed time: 00:00:01

  6. Finished recover at 2016-06-29 12:02:22
最後,可將tablespace置於Online。

點選(此處)摺疊或開啟

  1. SQL> alter tablespace users online;
除了可以使用備庫還原主庫,也可反過來用主庫還原備庫。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22621861/viewspace-2121174/,如需轉載,請註明出處,否則將追究法律責任。

相關文章