########
12.5.1 Flashing Back a Physical Standby Database to a Specific Point-in-Time
The following steps describe how to avoid re-creating a physical standby database after you issued the OPEN RESETLOGS
statement on the primary database.
Step 1 Determine the SCN before the RESETLOGS operation occurred.
On the primary database, use the following query to obtain the value of the system change number (SCN) that is 2 SCNs before the RESETLOGS
operation occurred on the primary database:
SQL> SELECT TO_CHAR(RESETLOGS_CHANGE# - 2) FROM V$DATABASE;
Step 2 Obtain the current SCN on the standby database.
On the standby database, obtain the current SCN with the following query:
SQL> SELECT TO_CHAR(CURRENT_SCN) FROM V$DATABASE;
Step 3 Determine if it is necessary to flash back the database.
If the value of CURRENT_SCN
is larger than the value of resetlogs_change# - 2, issue the following statement to flash back the standby database.
SQL> FLASHBACK STANDBY DATABASE TO SCN resetlogs_change# -2;
-
If the value of
CURRENT_SCN
is less than the value of the resetlogs_change# - 2, skip to Step . -
If the standby database's SCN is far enough behind the primary database's SCN, log apply services will be able to continue through the
OPEN RESETLOGS
statement without stopping. In this case, flashing back the database is unnecessary because log apply services do not stop upon reaching theOPEN RESETLOGS
statement in the redo data.
Step 4 Restart Redo Apply.
To start Redo Apply on the physical standby database, issue the following statement:
SQL> ALTER DATABASE RECOVER MANAGED STANDBY DATABASE DISCONNECT;
The standby database is now ready to receive and apply redo from the primary database.
有可能用到 primary 的 redo Log 做恢复。
####sample :
############sampe 1
primary:
SQL> select to_char(RESETLOGS_CHANGE#,999999999999999999999999) from v$database;TO_CHAR(RESETLOGS_CHANGE#,999999999999999999999999
-------------------------------------------------- 94660018598SQL> SELECT TO_CHAR(RESETLOGS_CHANGE# - 2) FROM V$DATABASE;
TO_CHAR(RESETLOGS_CHANGE#-2)
--------------------------------------------------------------------------------94660018596 standby: SQL> SELECT TO_CHAR(CURRENT_SCN) FROM V$DATABASE;TO_CHAR(CURRENT_SCN)
--------------------------------------------------------------------------------94659996840 Col name format a46Select name, sequence#, first_change# FROM v$archived_log where first_change > 94659996840;standby:
94660018596
alter database recover managed standby database cancel;
SBY>shutdown immediate; startup mount; flashback database to scn 94660018596; alter database open;select recid,thread#,sequence#,first_change#,next_change# from v$log_history where first_change > 94659996840 and next_change# < 94660018596 ;
###########primary Completed: ALTER DATABASE RECOVER database until cancel Thu May 31 20:03:14 2018alter database open resetlogsRESETLOGS after complete recovery through change 94660018597 -》 94660018597Archived Log entry 96541 added for thread 1 sequence 542 ID 0x6dc2cadd dest 1:Resetting resetlogs activation ID 1841482461 (0x6dc2cadd)
Thu May 31 20:09:37 2018
Setting recovery target incarnation to 3Thu May 31 20:09:37 2018Assigning activation ID 1841807754 (0x6dc7c18a)LGWR: STARTING ARCH PROCESSESThu May 31 20:09:37 2018ARC0 started with pid=23, OS id=29249 ARC0: Archival startedLGWR: STARTING ARCH PROCESSES COMPLETEARC0: STARTING ARCH PROCESSESThu May 31 20:09:38 2018ARC1 started with pid=24, OS id=29251 Thu May 31 20:09:38 2018ARC2 started with pid=25, OS id=29253 Thu May 31 20:09:38 2018ARC3 started with pid=26, OS id=29255 ARC1: Archival startedARC2: Archival startedARC1: Becoming the 'no FAL' ARCHARC1: Becoming the 'no SRL' ARCHARC2: Becoming the heartbeat ARCHThread 1 advanced to log sequence 2 (thread open)Thread 1 opened at log sequence 2 Current log# 2 seq# 2 mem# 0: /db/osas/data/osas/redo02.log############# stndbay Thu May 31 20:09:37 2018Setting recovery target incarnation to 3Thu May 31 20:09:37 2018Assigning activation ID 1841807754 (0x6dc7c18a)LGWR: STARTING ARCH PROCESSESThu May 31 20:09:37 2018ARC0 started with pid=23, OS id=29249 ARC0: Archival startedLGWR: STARTING ARCH PROCESSES COMPLETEARC0: STARTING ARCH PROCESSESThu May 31 20:09:38 2018ARC1 started with pid=24, OS id=29251 Thu May 31 20:09:38 2018ARC2 started with pid=25, OS id=29253 Thu May 31 20:09:38 2018ARC3 started with pid=26, OS id=29255 ARC1: Archival startedARC2: Archival startedARC1: Becoming the 'no FAL' ARCHARC1: Becoming the 'no SRL' ARCHARC2: Becoming the heartbeat ARCHThread 1 advanced to log sequence 2 (thread open)Thread 1 opened at log sequence 2 Current log# 2 seq# 2 mem# 0: /db/osas/data/osas/redo02.logThu May 31 20:09:40 2018RFS[820]: Assigned to RFS process 121969RFS[820]: New Archival REDO Branch: 977601794 Current: 977336000RFS[820]: Selected log 20 for thread 1 sequence 1 dbid 1825387057 branch 977601794RFS[820]: New Archival REDO Branch(resetlogs_id): 977601794 Prior: 977336000RFS[820]: Archival Activation ID: 0x6dc7c18a Current: 0x6dc2caddRFS[820]: Effect of primary database OPEN RESETLOGSRFS[820]: Incarnation entry added for Branch(resetlogs_id): 977601794 (osas) <- add new branchThu May 31 20:09:40 2018Setting recovery target incarnation to 3Thu May 31 20:09:40 2018Archived Log entry 51855 added for thread 1 sequence 1 ID 0x6dc7c18a dest 1:Thu May 31 20:09:41 2018RFS[821]: Assigned to RFS process 121973RFS[821]: Selected log 17 for thread 1 sequence 542 dbid 1825387057 branch 977336000Thu May 31 20:09:41 2018Archived Log entry 51856 added for thread 1 sequence 542 ID 0x6dc2cadd dest 1:
FS[821]: Assigned to RFS process 121973
RFS[821]: Selected log 17 for thread 1 sequence 542 dbid 1825387057 branch 977336000Thu May 31 20:09:41 2018Archived Log entry 51856 added for thread 1 sequence 542 ID 0x6dc2cadd dest 1:Thu May 31 20:09:42 2018RFS[822]: Assigned to RFS process 121977RFS[822]: Selected log 20 for thread 1 sequence 2 dbid 1825387057 branch 977601794Thu May 31 20:09:42 2018Primary database is in MAXIMUM PERFORMANCE modeRFS[823]: Assigned to RFS process 121979RFS[823]: Selected log 21 for thread 1 sequence 3 dbid 1825387057 branch 977601794Thu May 31 20:09:42 2018Archived Log entry 51857 added for thread 1 sequence 2 ID 0x6dc7c18a dest 1:Thu May 31 20:18:38 2018alter database recover managed standby database disconnectAttempt to start background Managed Standby Recovery process (osas)Thu May 31 20:18:38 2018MRP0 started with pid=31, OS id=122648 MRP0: Background Managed Standby Recovery process started (osas) started logmerger processhu May 31 20:18:43 2018
Managed Standby Recovery not using Real Time ApplyParallel Media Recovery started with 80 slavesMedia Recovery start incarnation depth : 1, target inc# : 3, irscn : 94660018597 《- scn 94660018597Waiting for all non-current ORLs to be archived...All non-current ORLs have been archived.Media Recovery Waiting for thread 1 sequence 541 branch(resetlogs_id) 977336000Fetching gap sequence in thread 1 branch(resetlogs_id) 977336000, gap seq 541-541Completed: alter database recover managed standby database disconnectThu May 31 20:20:35 2018
FAL[client]: Failed to request gap sequence GAP - thread 1 sequence 541-541 DBID 1825387057 branch 977336000FAL[client]: All defined FAL servers have been attempted.------------------------------------------------------------Check that the CONTROL_FILE_RECORD_KEEP_TIME initializationparameter is defined to a value that's sufficiently largeenough to maintain adequate log switch information to resolvearchivelog gaps.------------------------------------------------------------
######## 0
http://www.oracle-wiki.net/startdocshowtoconfigflashdb
1.flashback database
flashback database 如果 不开的话 ,那么就会使用undo log 来回滚数据库,回滚的时间大概在一天以内。
flashback database 如果 开的话,就是会使用flashback log 来回滚数据库,回滚的时间可以延长到好几天以前或者any time.
- Only run alter database flashback on; if there is a requirement to flashback to ANY previous point in time.
2.检查当前的回滚点的情况语句如下:
sqlplus '/ as sysdba'
SQL> select name, time,guarantee_flashback_databse from v$restore_point; SQL> alter session set nls_date_format='dd/mm/yy hh24:mi:ss';SQL> select oldest_flashback_scn,oldest_flashback_time from v$flashback_database_log;SQL> quit
Flashback database is useful feature introduced with 10g that allows the database to be effictively rewound to a previous point in time.
This feature is particularly useful for test, V&P, and development environments where you may wish to try out a new piece of code or fuctionality over and over, refining as you go. Rather than having to restore the database after each test, flashback database allows the database to be rewound very quickly to a previous point in time.
Flashback database can be effectively run in two modes. One mode where you log every change to every block, which allows you to flahsback the database to any previous point in time. Or another mode, where Oracle only tracks the "before" images of changed blocks, so that you can flashback to the start of the restore point.
How to Set-up Flashback Database
1. Ensure db_recovery_file_dest is set.
- sqlplus '/ as sysdba'
- SQL> alter system set db_recovery_file_dest='+<FRA Diskgroup>' SCOPE=spfile;
2. Ensure db_recovery_file_dest_size is set
- SQL> alter system set db_recovery_file_dest_size=100G SCOPE=spfile;
3. Stop and start the database
- sqlplus '/ as sysdba'
- SQL> shutdown immediate;
- SQL> startup mount;
- If flashback to any previous point in time is required, then turn flashback on using the following command
- SQL> alter database flashback on;
- SQL> alter database open;
- SQL> alter system set db_flashback_retention_target=2880;
NOTES
- Set the db_recovery_file_dest to an appropriate location for the flashback recovery files.
- Set the db_recovery_file_dest_size to an appropriate size for the amount and size of the testing required.
- Set the db_flashback_retention_target to an appropriate time, in mins, to retain flashbackability.
- Only run alter database flashback on; if there is a requirement to flashback to ANY previous point in time.
Determine if Flashback Database is Already Enabled
1. Run the following commands to determing Flashback is turned on.
- sqlplus '/ as sysdba'
- SQL> select flashback_on from v$database;
Creating and Using Flashback Restore points.
This worked example assumes the database is using ASM to manage its storage.
Createing a Restore point
Create a restore point whenever the database is at a state that it may needed to be flashed back to. Use the optional GUARANTEE FLASHBACK DATABASE clause to ensure that the restore point is not aged out of the flashback recovery area (FRA) as dictated by the db_flashback_retention_target parameter.
1. You may want to create the restore point in mount mode. If so, put the database into mount mode now.
2. Create a restore point
- sqlplus '/ as sysdba'
- SQL> create restore point <restore point name> [GUARANTEE FLASHBACK DATABASE];
Rolling Back to a Restore Point
1. Identify the Restore point
- sqlplus '/ as sysdba'
- SQL> select name, time,guarantee_flashback_databse from v$restore_point;
- SQL> quit
2. For a non RAC environment use the following commands to flashback to a restore point.
- sqlplus '/ as sysdba'
- SQL> shutdown immediate;
- SQL> startup mount;
- SQL> flashback database to restore point <restore point name>;
- SQL> alter database open resetlogs;
3. For RAC instances use the following commands.
- One one of the nodes run, srvctl stop database -d <database name> -o immediate
- sqlplus '/ as sysdba'
- SQL> startup mount;
- SQL> flashback database to restore point <restore point name>;
- SQL> alter database open resetlogs;
- SQL> shutdown immediate;
- SQL> quit
- srvctl start database -d <database name>
- Run crs_stat -t to confirm that the database is backup okay.
NOTES
- Any tables created and updated without the LOGGING option will be suseptable to block curruption errors when the database is flashed back. These can be remedied by issuing the TRUNCATE TABLE command against the affected object(s).
Dropping a Restore Point
1. Restore points can be dropped with the database open using the following commands
- sqlplus '/ as sysdba'
- SQL> drop restore poijnt <restore point name>;
- SQL> quit
Monitoring Flashback Logging
After enabling flashback logging, Oracle keeps track of the amount of logging generated. This can be queried from v$flashback_database_log, the estimate gets better with age. Note that this is the size of the flashback logs only and does not include space used by archive logs and RMAN backups.
1. Monitor flashback logs
- sqlplus '/ as sysdba'
- SQL> select estimated_flashback_size/1024/1024/1024 "EST_FLASHBACK_SIZE(GB)" from v$flashback_database_log;
- SQL> quit
Finding the Earliest Flashback Point
Querying V$flashback_database_log will show you the earliest point you can flashback your database to based on the size of the FRA and the currently available flashback logs.
1. Find the earliest flashback point
- sqlplus '/ as sysdba'
- SQL> alter session set nls_date_format='dd/mm/yy hh24:mi:ss';
- SQL> select oldest_flashback_scn,oldest_flashback_time from v$flashback_database_log;
- SQL> quit
Disabling Flashback Database
Full any previous point in time flashback can be disabled with the database open. Any unused Flashback logs will be automatically removed at this point and a message detailing the file deletion written to the alert log.
1. Disabling flashback
- sqlplus '/ as sysdba'
- SQL> ALTER DATABASE FLASHBACK OFF;
- SQL> quit
Troubleshooting
The following common errors can occur.
Message
ORA-38754: FLASHBACK DATABASE not started; required redo log is not available
Cause
Oracle needs to have the required archive logs in the archive destination at the time of flashback.
Solution
Use rman to restore the missing archive logs. The sequence and thread numbers are in the error message.
rman target / run{ allocate channel t1 device type 'sbt_tape'; FLASHBACK DATABASE TO RESTORE POINT; }
Now resume the flashback process from the RESETLOGS step.
Useful Scripts for Flashback
The following scripts can be used for flashing back a database automatically for a group of users. For example, a training environment.
################################### sample 1
###On the standby
Stop the apply process
SQL> ALTER DATABASE RECOVER MANAGED STANDBY DATABASE CANCEL;
Create a guaranteed restore pointSQL> CREATE RESTORE POINT SWITCHOVER_START_GRP GUARANTEE FLASHBACK DATABASE;
Start the apply process
SQL> ALTER DATABASE RECOVER MANAGED STANDBY DATABASE
USING CURRENT LOGFILE DISCONNECT; ###On the primaryCreate a guaranteed restore point
SQL> CREATE RESTORE POINT SWITCHOVER_START_GRP GUARANTEE FLASHBACK DATABASE;
####in primary :
----恢复到闪回点
SQL> shut abort
ORACLE instance shut down.
SQL> startup mount
ORACLE instance started.
Total System Global Area 1272213504 bytes
Fixed Size 1336260 bytes
Variable Size 922750012 bytes
Database Buffers 335544320 bytes
Redo Buffers 12582912 bytes
Database mounted.
SQL> flashback database to restore point SWITCHOVER_START_GRP;
Flashback complete.
SQL> alter database open resetlogs;
Database altered.
###in standby db;
Note: If a guaranteed restore points are created, make sure they are dropped post-switchover!
##########after switch over :
On the standby
SQL> drop restore point SWITCHOVER_START_GRP;
On the primary
Create a guaranteed restore point
SQL> drop restore point SWITCHOVER_START_GRP;
#####sample 2:
#####当前数据库是A->B(DGA) ,A->C(DGC) ,一主两备。B.C设置强制回滚点
现在是临时将B激活成主库,同C 库构成一个新的主备库关系,以用来做测试使用,在这期间,确保DB_RECOVERY_FILE_DEST_SIZE足够大。
测试完成,通过将B库/C库还原到强制还原点,同时再次与A库形成一主两备库模式
DG A:
25.8.1.7/8
DG B
58.2.101.3/4
####step 0 disable log_stat_2 and log_dest_3 主库A 关掉同步关系 alter system set log_archive_dest_state_2=defer sid='*' scope=both;alter system set log_archive_dest_state_3=defer sid='*' scope=both; ### step 1: setting DG A and DG b a restore point 创建强制回滚点,同时将B 库 (DG A) 设置为主库。方式failover
DG A:(create restore point and faiover and active DG A):
stop node 2 instance;
###below all done in instance 1
show parameter DB_RECOVERY_FILE_DEST_SIZE50ALTER DATABASE RECOVER MANAGED STANDBY DATABASE CANCEL;
shutdown immediate
startup mountselect to_char(RESETLOGS_CHANGE#,999999999999999999999999) from v$database;
CREATE RESTORE POINT DGA_START_GRP GUARANTEE FLASHBACK DATABASE;
select name,time,GUARANTEE_FLASHBACK_DATABASE from v$restore_point;
SELECT TO_CHAR(CURRENT_SCN) FROM V$DATABASE;
104986223361select fuzzy, status, error, recover, checkpoint_change#, checkpoint_time, count(*)
from v$datafile_headergroup by fuzzy, status, error, recover, checkpoint_change#, checkpoint_time ; alter database recover managed standby database finish; alter database commit to switchover to primary WITH SESSION SHUTDOWN; (WARNING: This will only succeed if the correct RECOVER FINISH-statement was issued before. If you forgot the 'SKIP STANDBY LOGFILE' although you have no Standby RedoLogs, the COMMIT to Switchover will fail with the error that more Media Recovery is required here.- If the COMMIT TO SWITCHOVER fails for any reason you have to use the ACTIVATE command which forces the Failover (and may cause Data Loss !!) SQL> ALTER DATABASE ACTIVATE STANDBY DATABASE;)alter database open;
SELECT TO_CHAR(CURRENT_SCN) FROM V$DATABASE;104986223918
###C库(DG B )创建强制回滚点
DG B (create restore point):stop node 2 instance;
show parameter DB_RECOVERY_FILE_DEST_SIZE120SQL> SELECT TO_CHAR(CURRENT_SCN) FROM V$DATABASE;
TO_CHAR(CURRENT_SCN)
----------------------------------------104986223362
###停下C(dgb)的节点2 ,所有操作在节点1操作,all done in instance 1
shutdown immediatestartup mountselect to_char(RESETLOGS_CHANGE#,999999999999999999999999) from v$database;
CREATE RESTORE POINT DGB_START_GRP GUARANTEE FLASHBACK DATABASE;
select name,time,GUARANTEE_FLASHBACK_DATABASE from v$restore_point;SELECT TO_CHAR(CURRENT_SCN) FROM V$DATABASE;SQL> SELECT TO_CHAR(CURRENT_SCN) FROM V$DATABASE;
TO_CHAR(CURRENT_SCN)
----------------------------------------104986223362
###DG A: (chage log_arch_dest paramter to make DG A and DG B to a new DG SYNC conf)
(修改DGA(B) 同步归档参数,确保DGA 归档到DG B,同时不会同步归档到primary, 这2个库构成一个新的DG 关系,以用来测试)fal_client dba2-old/dba1-old
fal_server dbalog_archive_dest_2 SERVICE=dba lgwr async noaffirm reopen=60 valid_for=(online
_logfiles,primary_role) db_unique_name=dbalog_archive_dest_3 SERVICE=rdba lgwr async noaffirm reopen=60 valid_for=(stand
by_logfiles,standby_role) db_unique_name=rdbalog_archive_dest_state_2 ENABLE
log_archive_dest_state_3 DEFER change:alter system set log_archive_dest_3='SERVICE=rdba lgwr async noaffirm reopen=60 valid_for=(online_logfiles,primary_role) db_unique_name=rdba' sid='*' scope=both;alter system set log_archive_dest_state_3=ENABLE sid='*' scope=both;
alter system set log_archive_dest_state_2=defer sid='*' scope=both;
###DG B: (begin MRP ,dg sync is ok)
(DGB (C) 开启MRP,测试同步是否正常)--ALTER DATABASE RECOVER MANAGED STANDBY DATABASE DISCONNECT;
alter database recover managed standby database using current logfile disconnect; fal_client dba1-1-old/dba2-1-old fal_server dbalog_archive_config DG_CONFIG=(dba,sdba,rdba)log_archive_dest_2 SERVICE=sdba lgwr async noaffirm reopen=60 valid_for=(online_logfiles,primary_role) db_unique_name=sdbalog_archive_dest_3 SERVICE=dba lgwr async noaffirm reopen=60 valid_for=(online_logfiles,primary_role) db_unique_name=dba
log_archive_dest_state_2 ENABLE
log_archive_dest_state_3 ENABLE change:alter system set fal_server=rdba sid='*' scope=both;alter system set fal_client='dba1-1-old' sid='dba1' scope=both;alter system set log_archive_dest_state_3=defer sid='*' scope=both; ####开始DGA 和DGB 的主库和容灾库的测试,该测试主要关注的是,容灾库是否只要打开一个节点,还是同时打开2个节点,###因为发现容灾库在同时打开2个节点时候,测试使用脚本切换的时候,时间会超过15分钟。###因为发现容灾库在同时打开1个节点时候,测试使用脚本切换的时候,时间会超过5分钟。##after both standby rac is rstart.开启2个节点的容灾库,开始测试
##prim lns communicate with standby rfs will need 3 minutes,主要关注LNS 写入速度#-- Query v$managed_standby to see the status of processes involved in the shipping redo on this system.
#--Does not include processes needed to apply redo.set linesize 900SELECT inst_id, thread#, process, pid, status, client_process, client_pid, sequence#, block#, active_agents, known_agents FROM gv$managed_standby ORDER BY thread#, pid;--DG 库端,关注RFS和LGWR 的通信 ,正常情况下,instance1有2个process RFS 跟主库的LGWR通信 ,instance 2 有2个process RFS 跟主库的LGWR通信
set linesize 900SELECT inst_id, thread#, process, pid, status, client_process, client_pid, sequence#, block#, active_agents, known_agents FROM gv$managed_standby ORDER BY thread#, pid;INST_ID THREAD# PROCESS PID STATUS CLIENT_P CLIENT_PID SEQUENCE# BLOCK# ACTIVE_AGENTS KNOWN_AGENTS
---------- ---------- --------- ---------- ------------ -------- ---------------------------------------- ---------- ---------- ------------- ------------ 1 2 RFS 11862220 IDLE LGWR 26083514 31 135 0 0 1 1 RFS 10486134 IDLE LGWR 11993218 40 612 --关闭一个standby instance2, 该实例instance2 跟prim实例2通信的RFS会消失,只等主库2日志切换达到4-5次,才能再次看到RFS,可以理解成RFS的切换INST_ID THREAD# PROCESS PID STATUS CLIENT_P CLIENT_PID SEQUENCE# BLOCK# ACTIVE_AGENTS KNOWN_AGENTS
---------- ---------- --------- ---------- ------------ -------- ---------------------------------------- ---------- ---------- ------------- ------------ 1 2 RFS 11862220 IDLE LGWR 26083514 38 135 0 0
###开始DG A (prim)和DG B (standby)的switchover.测试完成
DG A (prim)
shutdown instance 2
##below is all done instance 1SELECT SWITCHOVER_STATUS FROM V$DATABASE;SWITCHOVER_STATUS--------------------RESOLVABLE GAP10 seconnds
SWITCHOVER_STATUS--------------------SESSIONS ACTIVEalter system switch logfile ;
alter system archive log current;alter system checkpoint;select switchover_status from v$database;
SESSIONS ACTIVEalter database commit to switchover to physical standby with session shutdown;
DG B (standby)
select switchover_status from v$database;alter database commit to switchover to primary with session shutdown;shutdown immediatestartup DG A (prim)conn / as sysdbastartupalter database recover managed standby database using current logfile disconnect; ###测试完成后,开始用回滚点恢复dga (prim)和dgb(now pimary) 到回滚点,同时与A库构成一主两备的模式 ,begin to test remote dg restore potint##(发现当数据库是standby 库,回滚数据库 到回滚点是可以顺利进行,总是提示开始恢复归档日志时候,归档日志序列号不对,只能通过迂回方式,先active standby到primary,在恢复到回滚点) DG A (now standby ,):startup mountstop mrpalter database recover managed standby database finish;alter database commit to switchover to primary WITH SESSION SHUTDOWN;
(now primary)
flashback database to restore point DGA_START_GRP;alter database convert to physical standby;select open_mode from v$database;start mrpdrop restore point DGA_START_GRP;DG B: (now pimary)
startup mountstop mrpflashback database to restore point DGB_START_GRP;alter database convert to physical standby;select open_mode from v$database;start mrpdrop restore point DGB_START_GRP;
https://blog.csdn.net/u012366626/article/details/40003609
ORA-10456: cannot open standby database; media recovery session may be inHow To Failover and Flashback a Physical Standby for testing without recreating broker configuration and database (文档 ID 2060572.1)
####issue after flashback db to standby mode ,mrp start failed with error
日志
Managed Standby Recovery not using Real Time ApplyMon May 27 17:44:20 2019Warning: Recovery target destination is in a sibling branchof the controlfile checkpoint. Recovery will only recoverchanges to datafiles.Datafile 1 (ckpscn 104987799903) is orphaned on incarnation#=1MRP0: Detected orphaned datafiles! Recovery will possibly be retried after flashback...Errors in file /db/dba/oracleapp/database/11.2.0/diag/rdbms/rdba/dba1/trace/dba1_pr00_12583054.trc:ORA-19909: datafile 1 belongs to an orphan incarnationORA-01110: data file 1: '+dba_DATA/dba/datafile/system.283.964975893'Recovery Slave PR00 previously exited with exception 19909Mon May 27 17:44:40 2019
检查:
pri:
RMAN> list incarnation of database;using target database control file instead of recovery catalog
List of Database Incarnations
DB Key Inc Key DB Name DB ID STATUS Reset SCN Reset Time------- ------- -------- ---------------- --- ---------- ----------1 1 dba 1071884928 CURRENT 1 20-NOV-14 standbyRMAN> list incarnation of database;RMAN> list incarnation of database;
using target database control file instead of recovery catalog
List of Database IncarnationsDB Key Inc Key DB Name DB ID STATUS Reset SCN Reset Time------- ------- -------- ---------------- --- ---------- ----------1 1 dba 1071884928 PARENT 1 20-NOV-142 2 dba 1071884928 PARENT 104986223364 24-MAY-193 3 dba 1071884928 CURRENT 104987083382 27-MAY-19 solution:RMAN> reset database to incarnation 1;
########### 2
很多人在学习flashback database这个oracle技术的时候,都会有一个疑问,就是如果我只有一个数据库作为生产库的话,是否有这样的业务需求导致我们要把数据库闪回到以前的时间点?以及这样做是否值得(当前时间点和闪回目的时间点中间的所有操作将丢失)?
其实抛开这个问题的讨论,在oracle的dataguard环境配置中,对于故障切换后产生故障的主机从新回到dataguard环境,以及处于测试的目的我们人为的激活了备库,flashback database都可以提供非常好的选择。下面的例子描述了这样一个场景:用户需要一个和生产系统一样或者类似的测试环境,但是单纯的搭建一个环境显然是不值得的,对于部署了dataguard环境的生产系统来说,我们可以选择把备库临时激活,以读写的方式打开,用于测试的需要,等测试结束后,把备库通过flashback database技术闪回到激活之前的时间点,从新的加入到dataguard配置环境中。
第1 步 准备要被激活的物理备数据库。
1 .检查数据库的flashback database模式和闪回日志存放的目录。(也可以是NO ,只是会使用undo 回滚)
SQL> select flashback_on from v$database;FLASHBACK_ON------------------YESSQL> show parameter db_recovery_file
NAME TYPE VALUE------------------------------------ ----------- ------------------------------db_recovery_file_dest string /u01/app/oracle/flash_recovery_areadb_recovery_file_dest_size big integer 2G2 .由于备库在应用日志,所以要取消日志应用,并创建一个激活之前的还原点。
SQL> select process,status from v$managed_standby;PROCESS STATUS
--------- ------------ARCH CONNECTEDARCH CLOSINGMRP0 WAIT_FOR_LOGRFS IDLERFS IDLERFS IDLE6 rows selected.SQL> recover managed standby database cancel;
SQL> create restore point test_scn guarantee flashback database;Restore point created.第2 步 准备主数据库1 .归档当前日志文件。在主数据库上,切换日志使得还原点(在步骤 1 中创建)的 SCN 将在物理备数据库上被归档:SQL> ALTER SYSTEM ARCHIVE LOG CURRENT;当使用备重做日志文件时,这个步骤是必须的以确保数据库能被正确地闪回到还原点。2 .延迟指向将被激活的备的日志归档目的地。SQL> ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_2=DEFER;System altered.
SQL> show parameter log_archive_dest_state_2
NAME TYPE VALUE------------------------------------ ----------- ------------------------------log_archive_dest_state_2 string DEFER 第3 步 激活物理备数据库。在物理备数据库上,执行下述步骤:1 .激活物理备数据库并打开到open状态:SQL> ALTER DATABASE ACTIVATE STANDBY DATABASE;SQL> ALTER DATABASE OPEN; 第4 步 使用激活的数据库用于报表或测试。一旦备数据库已经被激活,你能运行报表工具或执行其它测试并激活几天甚至几周,独立于主数据库。警告:当数据库被激活时,它不从主数据库接收重做数据库并不能提供灾难保护。建议至少有两个物理备数据库参与配置,使得主数据库保持对数据丢失的保护。 第5 步 回复激活的数据库回到物理备数据库。在你完成测试之后,你需要重新与主数据库同步激活的数据库。在激活的数据库上执行下面语句以快速闪回它到保障的还原点并将它重新与主数据库同步:SQL> shutdown immediateDatabase closed.Database dismounted.ORACLE instance shut down.SQL> startup mountORACLE instance started.Total System Global Area 314572800 bytes
Fixed Size 1219160 bytesVariable Size 75498920 bytesDatabase Buffers 234881024 bytesRedo Buffers 2973696 bytesDatabase mounted.SQL> flashback database to restore point test_scn;
Flashback complete.SQL> alter database convert to physical standby;
Database altered.SQL> select status from v$instance;
STATUS------------STARTEDSQL> shutdown immediate
ORA-01507: database not mountedORACLE instance shut down.
SQL> startup mountORACLE instance started.Total System Global Area 314572800 bytes
Fixed Size 1219160 bytesVariable Size 75498920 bytesDatabase Buffers 234881024 bytesRedo Buffers 2973696 bytesDatabase mounted.SQL> recover managed standby database disconnect;Media recovery complete. 第6 步 重新允许归档到物理备数据库目的地。在主数据库上,执行下面语句来重新允许归档到物理备数据库:SQL> ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_2=ENABLE;
第7 步 测试dataguard环境工作正常1.在主库删除表空间usertest,并切换日志
SQL> select name from v$datafile;NAME--------------------------------------------------------------------------------/u01/app/oracle/oradata/db01/system01.dbf/u01/app/oracle/oradata/db01/undotbs01.dbf/u01/app/oracle/oradata/db01/sysaux01.dbf/u01/app/oracle/oradata/db01/users01.dbf/u01/app/oracle/oradata/db01/example01.dbf/u01/app/oracle/oradata/db01/usertest01.dbf6 rows selected.
SQL> drop tablespace usertest including contents and datafiles;
Tablespace dropped.SQL> alter system switch logfile;
System altered.2.在备库观察日志操作是否正确应用,下面的查询可以看到文件应经被删除,说明主库的日志应用到备库。
SQL> select name from v$datafile;NAME
---------------------------------------------------------------------------------------/u01/app/oracle/oradata/db01/system01.dbf/u01/app/oracle/oradata/db01/undotbs01.dbf/u01/app/oracle/oradata/db01/sysaux01.dbf/u01/app/oracle/oradata/db01/users01.dbf/u01/app/oracle/oradata/db01/example01.dbf
################33
4)闪回日志在出现空间压力的情况下,oracle会自动删除闪回日志,则有可能导致无法闪回到指定的时间点。如果希望闪回到指定的时间点,可进行如下操作
----创建闪回点
SQL> create restore point flashback_20160515 guarantee flashback database;
Restore point created.
SQL> select name from v$restore_point;
NAME
----------------------------------------
FLASHBACK_20160515
----恢复到闪回点
SQL> shut abort
ORACLE instance shut down.
SQL> startup mount
ORACLE instance started.
Total System Global Area 1272213504 bytes
Fixed Size 1336260 bytes
Variable Size 922750012 bytes
Database Buffers 335544320 bytes
Redo Buffers 12582912 bytes
Database mounted.
SQL> flashback database to restore point flashback_20160515;
Flashback complete.
SQL> alter database open resetlogs;
Database altered.
----清理闪回点
SQL> select name from v$restore_point;
NAME
----------------------------------------
FLASHBACK_20160515
SQL> drop restore point flashback_20160515;
Restore point dropped.
SQL> select name from v$restore_point;
no rows selected