問題描述:情形是當主庫真正出現異常以後,纔會執行的操做,那麼咱們執行過failover 以後,如何在從新構建DG,這裏咱們利用flashback database來重構。模擬前主庫要開啓閃回區,不然要從新搭建DG了數據庫
1.因爲主庫已經不可訪問,下面全部的操做都在備庫完成,先取消實時同步session
SQL> alter database recover managed standby database cancel;app
2.強制取消redo接收spa
3.確認一下備庫3d
4.切換爲物理主庫,而後open,確認一下切換成功,由於原先的主庫尚未關閉,可能會產生一些鏈接,因此如今的狀態是GAP,至此failover操做完成,原來的備庫已經切換爲主庫,能夠給業務提供服務了blog
SQL> alter database commit to switchover to primary with session shutdown;進程
SQL> alter database open;同步
SQL> select switchover_status,database_role,open_mode from v$database;flash
5.failover恢復,在新的主庫執行,查詢到scn值it
SQL> select to_char(standby_became_primary_scn) from v$database;
6.在以前的主庫如今的備庫上執行,個人以前是startup狀態,調整一下如今備庫的狀態
SQL> shutdown immediate
SQL> startup mount
7.恢復閃回區scn值
SQL> flashback database to scn 1388059
8.更改狀態
SQL> alter database convert to physical standby;
SQL> shutdown immediate
SQL> startup
9.開啓實時同步
SQL> alter database recover managed standby database using current logfile disconnect from session;
10.分別查看一下主備庫的切換狀態,以及數據庫角色是否正常
SQL> select switchover_status,database_role,open_mode from v$database;
如今的備庫:
如今的主庫:已經再也不顯示GAP,如今指向備庫,到此failover結束
11.相關命令
中止實時同步:SQL> alter database recover managed standby database cancel;
強制停掉redo apply:SQL> alter database recover managed standby database finish force; //危險操做,一旦執行,rfs、mrp進程就會停掉
轉換物理備庫:SQL> alter database commit to switchover to primary with session shutdown;
查詢狀態角色:SQL> select switchover_status,database_role,open_mode from v$database;
查詢SCN號 :SQL> select to_char(standby_became_primary_scn) from v$database;
閃回到序列號:SQL> flashback database to scn 1388059
切換主庫爲備庫:SQL> alter database convert to physical standby;
開啓實時同步:SQL> alter database recover managed standby database using current logfile disconnect from session;